QUERY PLAN
Aggregate (cost=105.96..105.97 rows=1 width=720)
-> Nested Loop Left Join (cost=81.37..105.62 rows=1 width=11)
-> Nested Loop Left Join (cost=81.09..97.31 rows=1 width=13)
-> Nested Loop (cost=80.81..89.01 rows=1 width=13)
-> GroupAggregate (cost=80.53..80.56 rows=1 width=12)
Group Key: subpsl.project_id
Filter: ((min(subpsl.id) IS NOT NULL) AND (max(subpsl.id) IS NOT NULL))
-> Sort (cost=80.53..80.53 rows=1 width=8)
Sort Key: subpsl.project_id
-> Seq Scan on tbl_project_status_logs subpsl (cost=0.00..80.52 rows=1 width=8)
Filter: ((created_at >= '2025-08-21 00:00:00+08'::timestamp with time zone) AND (created_at < '2025-08-22 00:00:00'::timestamp without time zone))
-> Index Scan using tbl_projects_pkey on tbl_projects p (cost=0.28..8.30 rows=1 width=9)
Index Cond: (id = subpsl.project_id)
Filter: (created_by = 1001)
-> Index Scan using tbl_project_status_logs_pkey on tbl_project_status_logs minpsl (cost=0.28..8.30 rows=1 width=8)
Index Cond: ((min(subpsl.id)) = id)
-> Index Scan using tbl_project_status_logs_pkey on tbl_project_status_logs maxpsl (cost=0.28..8.30 rows=1 width=6)
Index Cond: ((max(subpsl.id)) = id)