QUERY PLAN
GroupAggregate (cost=3006.43..3012.02 rows=200 width=12)
Group Key: tbl_work_logs.created_by
-> Sort (cost=3006.43..3007.63 rows=479 width=8)
Sort Key: tbl_work_logs.created_by
-> HashAggregate (cost=2975.52..2980.31 rows=479 width=8)
Group Key: tbl_work_logs.created_by, tbl_work_logs.client_id
-> Append (cost=324.51..2973.13 rows=479 width=8)
-> Bitmap Heap Scan on tbl_work_logs (cost=324.51..2212.23 rows=395 width=8)
Recheck Cond: (created_by = ANY ('{5332,1001,5087,5467,5300,5311,5295,1013,5476,1004,1005,5449}'::integer[]))
Filter: ((NOT is_draft) AND (client_id IS NOT NULL) AND (start_at >= '2025-08-01 00:00:00+08'::timestamp with time zone) AND (start_at <= '2025-12-31 23:59:59+08'::timestamp with time zone))
-> Bitmap Index Scan on tbl_work_logs_created_by_idx (cost=0.00..324.41 rows=17724 width=0)
Index Cond: (created_by = ANY ('{5332,1001,5087,5467,5300,5311,5295,1013,5476,1004,1005,5449}'::integer[]))
-> Bitmap Heap Scan on tbl_schedules (cost=132.18..756.11 rows=84 width=8)
Recheck Cond: (created_by = ANY ('{5332,1001,5087,5467,5300,5311,5295,1013,5476,1004,1005,5449}'::integer[]))
Filter: ((client_id IS NOT NULL) AND (created_at >= '2025-08-01 00:00:00+08'::timestamp with time zone) AND (created_at <= '2025-12-31 23:59:59+08'::timestamp with time zone))
-> Bitmap Index Scan on tbl_schedules_created_by_idx (cost=0.00..132.16 rows=7031 width=0)
Index Cond: (created_by = ANY ('{5332,1001,5087,5467,5300,5311,5295,1013,5476,1004,1005,5449}'::integer[]))