QUERY PLAN
Aggregate (cost=240.26..240.27 rows=1 width=8)
-> Sort (cost=240.18..240.20 rows=5 width=726)
Sort Key: p.bargain_date DESC, p.updated_at DESC
-> Subquery Scan on p (cost=239.98..240.13 rows=5 width=726)
-> GroupAggregate (cost=239.98..240.08 rows=5 width=762)
Group Key: p_1.id, r.user_id, (sum(r.pct))
-> Sort (cost=239.98..239.99 rows=5 width=60)
Sort Key: p_1.id, r.user_id, (sum(r.pct))
-> Hash Right Join (cost=224.67..239.92 rows=5 width=60)
Hash Cond: (t.project_id = p_1.id)
-> HashAggregate (cost=25.64..33.23 rows=607 width=40)
Group Key: t.project_id, r.user_id
-> Hash Right Join (cost=1.20..21.09 rows=607 width=40)
Hash Cond: (r.erp_profit_distribute_id = t.id)
-> Seq Scan on tbl_erp_profit_distribute_pcts r (cost=0.00..17.80 rows=780 width=40)
-> Hash (cost=1.11..1.11 rows=7 width=8)
-> Seq Scan on tbl_erp_profit_distributes t (cost=0.00..1.11 rows=7 width=8)
Filter: ((project_id IS NOT NULL) AND (status = 2))
-> Hash (cost=198.96..198.96 rows=5 width=24)
-> Seq Scan on tbl_projects p_1 (cost=0.00..198.96 rows=5 width=24)
Filter: ((collected < budget) AND (bargain_date >= '2025-08-01'::date) AND (bargain_date <= '2025-08-31'::date) AND (project_status = 3))