QUERY PLAN
Aggregate (cost=2570.68..2570.69 rows=1 width=8)
-> Sort (cost=2569.78..2569.93 rows=60 width=65)
Sort Key: w.start_at
-> Subquery Scan on w (cost=79.01..2568.01 rows=60 width=65)
-> Append (cost=79.01..2567.41 rows=60 width=65)
-> Nested Loop Left Join (cost=79.01..1467.53 rows=1 width=307)
Join Filter: (wlso.id = w_1.scenario_option_id)
-> Bitmap Heap Scan on tbl_work_logs w_1 (cost=79.01..1465.65 rows=1 width=32)
Recheck Cond: (created_by = 5295)
Filter: ((start_at IS NOT NULL) AND (end_at IS NOT NULL) AND (NOT is_draft) AND (((start_at >= '2025-06-25 00:00:00+08'::timestamp with time zone) AND (end_at < '2025-06-25 23:59:59+08'::timestamp with time zone)) OR ((start_at <= '2025-06-25 00:00:00+08'::timestamp with time zone) AND (end_at > '2025-06-25 00:00:00+08'::timestamp with time zone)) OR ((start_at <= '2025-06-25 23:59:59+08'::timestamp with time zone) AND (end_at > '2025-06-25 23:59:59+08'::timestamp with time zone))))
-> Bitmap Index Scan on tbl_work_logs_created_by_idx (cost=0.00..79.01 rows=4096 width=0)
Index Cond: (created_by = 5295)
-> Seq Scan on tbl_work_log_scenario_options wlso (cost=0.00..1.39 rows=39 width=278)
-> Result (cost=14.76..1099.87 rows=59 width=65)
-> Append (cost=14.76..1099.28 rows=59 width=65)
-> Bitmap Heap Scan on tbl_schedules (cost=14.76..363.12 rows=54 width=110)
Recheck Cond: ((created_by = ANY ('{5300,5295,5295}'::integer[])) AND (created_by = 5295))
Filter: (((start_at IS NOT NULL) OR (end_at IS NOT NULL)) AND (((CASE WHEN (start_at IS NULL) THEN CASE WHEN (end_at < now()) THEN CASE WHEN is_complete THEN created_at ELSE end_at END ELSE CASE WHEN is_complete THEN created_at ELSE now() END END ELSE start_at END >= '2025-06-25 00:00:00+08'::timestamp with time zone) AND (CASE WHEN (end_at IS NULL) THEN CASE WHEN (start_at > now()) THEN start_at ELSE CASE WHEN is_complete THEN complete_at ELSE now() END END ELSE CASE WHEN ((start_at IS NULL) AND (end_at < now())) THEN CASE WHEN is_complete THEN complete_at ELSE now() END ELSE end_at END END < '2025-06-25 23:59:59+08'::timestamp with time zone)) OR ((CASE WHEN (start_at IS NULL) THEN CASE WHEN (end_at < now()) THEN CASE WHEN is_complete THEN created_at ELSE end_at END ELSE CASE WHEN is_complete THEN created_at ELSE now() END END ELSE start_at END <= '2025-06-25 00:00:00+08'::timestamp with time zone) AND (CASE WHEN (end_at IS NULL) THEN CASE WHEN (start_at > now()) THEN start_at ELSE CASE WHEN is_complete THEN complete_at ELSE now() END END ELSE CASE WHEN ((start_at IS NULL) AND (end_at < now())) THEN CASE WHEN is_complete THEN complete_at ELSE now() END ELSE end_at END END > '2025-06-25 00:00:00+08'::timestamp with time zone)) OR ((CASE WHEN (start_at IS NULL) THEN CASE WHEN (end_at < now()) THEN CASE WHEN is_complete THEN created_at ELSE end_at END ELSE CASE WHEN is_complete THEN created_at ELSE now() END END ELSE start_at END <= '2025-06-25 23:59:59+08'::timestamp with time zone) AND (CASE WHEN (end_at IS NULL) THEN CASE WHEN (start_at > now()) THEN start_at ELSE CASE WHEN is_complete THEN complete_at ELSE now() END END ELSE CASE WHEN ((start_at IS NULL) AND (end_at < now())) THEN CASE WHEN is_complete THEN complete_at ELSE now() END ELSE end_at END END > '2025-06-25 23:59:59+08'::timestamp with time zone))))
-> Bitmap Index Scan on tbl_schedules_created_by_idx (cost=0.00..14.75 rows=189 width=0)
Index Cond: ((created_by = ANY ('{5300,5295,5295}'::integer[])) AND (created_by = 5295))
-> Subquery Scan on "*SELECT* 3" (cost=0.00..735.62 rows=5 width=65)
-> Seq Scan on tbl_calendars c (cost=0.00..735.57 rows=5 width=78)
Filter: ((start_at IS NOT NULL) AND (end_at IS NOT NULL) AND (created_by = 5295) AND (((start_at >= '2025-06-25 00:00:00+08'::timestamp with time zone) AND (end_at < '2025-06-25 23:59:59+08'::timestamp with time zone)) OR ((start_at <= '2025-06-25 00:00:00+08'::timestamp with time zone) AND (end_at > '2025-06-25 00:00:00+08'::timestamp with time zone)) OR ((start_at <= '2025-06-25 23:59:59+08'::timestamp with time zone) AND (end_at > '2025-06-25 23:59:59+08'::timestamp with time zone))))