| Sort (cost=2044.04..2044.05 rows=4 width=65) |
| Sort Key: w.start_at |
| -> Nested Loop (cost=95.44..2044.00 rows=4 width=65) |
| -> Seq Scan on tbl_users u (cost=0.00..8.12 rows=1 width=4) |
| Filter: ((id = 5064) AND (department_id = 10)) |
| -> Append (cost=95.44..2035.80 rows=4 width=65) |
| -> Nested Loop Left Join (cost=95.44..271.86 rows=1 width=307) |
| Join Filter: (wlso.id = w.scenario_option_id) |
| -> Bitmap Heap Scan on tbl_work_logs w (cost=95.44..269.98 rows=1 width=32) |
| Recheck Cond: ((created_by = ANY ('{1000,1001,1004,1005,1011,1013,1015,1022,1023,5016,5064,5085,5087,5248,5250,5252,5295,5300,5311,5332,5360,5388,5446,5449}'::integer[])) AND (created_by = 5064)) |
| Filter: ((NOT is_draft) AND (((start_at >= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at < '2025-12-17 23:59:59+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at > '2025-12-17 00:00:00+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 23:59:59+08'::timestamp with time zone) AND (end_at > '2025-12-17 23:59:59+08'::timestamp with time zone))) AND (((start_at >= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at < '2025-12-17 23:59:59+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at > '2025-12-17 00:00:00+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 23:59:59+08'::timestamp with time zone) AND (end_at > '2025-12-17 23:59:59+08'::timestamp with time zone)))) |
| -> Bitmap Index Scan on tbl_work_logs_created_by_idx (cost=0.00..95.44 rows=50 width=0) |
| Index Cond: ((created_by = ANY ('{1000,1001,1004,1005,1011,1013,1015,1022,1023,5016,5064,5085,5087,5248,5250,5252,5295,5300,5311,5332,5360,5388,5446,5449}'::integer[])) AND (created_by = 5064)) |
| -> Seq Scan on tbl_work_log_scenario_options wlso (cost=0.00..1.39 rows=39 width=278) |
| -> Result (cost=150.72..1763.94 rows=3 width=65) |
| -> Append (cost=150.72..1763.91 rows=3 width=65) |
| -> Hash Right Join (cost=150.72..163.44 rows=2 width=109) |
| Hash Cond: (ccr.schedule_id = tbl_schedules.id) |
| Filter: (((tbl_schedules.is_public = 1) AND (tbl_schedules.created_by <> 5064)) OR (tbl_schedules.created_by = 5064) OR (ccr.user_id = 5064)) |
| -> Seq Scan on tbl_schedule_carbon_copy_rels ccr (cost=0.00..10.87 rows=687 width=8) |
| -> Hash (cost=150.69..150.69 rows=2 width=141) |
| -> Bitmap Heap Scan on tbl_schedules (cost=83.08..150.69 rows=2 width=141) |
| Recheck Cond: ((created_by = ANY ('{1000,1001,1004,1005,1011,1013,1015,1022,1023,5016,5064,5085,5087,5248,5250,5252,5295,5300,5311,5332,5360,5388,5446,5449}'::integer[])) AND (created_by = 5064)) |
| 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-12-17 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-12-17 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-12-17 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-12-17 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-12-17 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-12-17 23:59:59+08'::timestamp with time zone))) 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-12-17 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-12-17 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-12-17 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-12-17 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-12-17 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-12-17 23:59:59+08'::timestamp with time zone)))) |
| -> Bitmap Index Scan on tbl_schedules_created_by_idx (cost=0.00..83.08 rows=19 width=0) |
| Index Cond: ((created_by = ANY ('{1000,1001,1004,1005,1011,1013,1015,1022,1023,5016,5064,5085,5087,5248,5250,5252,5295,5300,5311,5332,5360,5388,5446,5449}'::integer[])) AND (created_by = 5064)) |
| -> Subquery Scan on "*SELECT* 3" (cost=0.00..1600.45 rows=1 width=65) |
| -> Seq Scan on tbl_calendars c (cost=0.00..1600.44 rows=1 width=78) |
| Filter: ((created_by = 5064) AND (((is_public = 1) AND (created_by <> 5064)) OR (created_by = 5064)) AND (((start_at >= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at < '2025-12-17 23:59:59+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at > '2025-12-17 00:00:00+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 23:59:59+08'::timestamp with time zone) AND (end_at > '2025-12-17 23:59:59+08'::timestamp with time zone))) AND (((start_at >= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at < '2025-12-17 23:59:59+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 00:00:00+08'::timestamp with time zone) AND (end_at > '2025-12-17 00:00:00+08'::timestamp with time zone)) OR ((start_at <= '2025-12-17 23:59:59+08'::timestamp with time zone) AND (end_at > '2025-12-17 23:59:59+08'::timestamp with time zone))) AND (created_by = ANY ('{1000,1001,1004,1005,1011,1013,1015,1022,1023,5016,5064,5085,5087,5248,5250,5252,5295,5300,5311,5332,5360,5388,5446,5449}'::integer[]))) |