QUERY PLAN
GroupAggregate (cost=607.48..607.59 rows=4 width=42)
Group Key: sub.new_status
-> Sort (cost=607.48..607.50 rows=6 width=7)
Sort Key: sub.new_status
-> Subquery Scan on sub (cost=498.27..607.40 rows=6 width=7)
Filter: ((sub.new_status = ANY ('{1,2}'::integer[])) AND (sub.rn = 1))
-> WindowAgg (cost=498.27..560.63 rows=3118 width=27)
-> Sort (cost=498.27..506.07 rows=3118 width=19)
Sort Key: l.project_id, l.created_at DESC
-> Hash Join (cost=217.10..317.33 rows=3118 width=19)
Hash Cond: (l.project_id = p.id)
-> Seq Scan on tbl_project_status_logs l (cost=0.00..92.03 rows=3118 width=14)
Filter: ((created_at < '2026-01-01 00:00:00+08'::timestamp with time zone) AND (new_status > 0))
-> Hash (cost=177.60..177.60 rows=3160 width=9)
-> Seq Scan on tbl_projects p (cost=0.00..177.60 rows=3160 width=9)