QUERY PLAN
Aggregate (cost=1123.41..1123.42 rows=1 width=104)
-> Sort (cost=1123.27..1123.28 rows=6 width=571)
Sort Key: (CASE WHEN (t0_2.id IS NOT NULL) THEN t0_2.remind_date ELSE sc.signed_at END) DESC
-> Hash Left Join (cost=1084.17..1123.19 rows=6 width=571)
Hash Cond: (c.sales_rep = sgr.sales_id)
-> Hash Right Join (cost=1082.06..1121.00 rows=6 width=80)
Hash Cond: (t0.id = sc.id)
-> HashAggregate (cost=329.62..345.99 rows=1637 width=44)
Group Key: t0.id
-> Hash Right Join (cost=173.27..319.33 rows=2059 width=36)
Hash Cond: ("*SELECT* 1".contract_id = t0.id)
-> Append (cost=88.44..229.08 rows=2059 width=36)
-> Subquery Scan on "*SELECT* 1" (cost=88.44..164.60 rows=2056 width=36)
-> Hash Join (cost=88.44..144.04 rows=2056 width=124)
Hash Cond: (r.erp_collect_ticket_id = t.id)
-> Seq Scan on tbl_erp_collect_ticket_settles r (cost=0.00..34.77 rows=2059 width=12)
Filter: (sales_contract_id IS NOT NULL)
-> Hash (cost=61.74..61.74 rows=2136 width=4)
-> Seq Scan on tbl_erp_collect_tickets t (cost=0.00..61.74 rows=2136 width=4)
Filter: (status = ANY ('{2,5}'::integer[]))
-> Subquery Scan on "*SELECT* 2" (cost=0.28..9.33 rows=1 width=36)
-> Nested Loop (cost=0.28..9.32 rows=1 width=124)
-> Seq Scan on tbl_erp_cash_cost_ticket_sales_contract_settles r_1 (cost=0.00..1.01 rows=1 width=12)
Filter: (sales_contract_id IS NOT NULL)
-> Index Scan using tbl_erp_cash_cost_tickets_pkey on tbl_erp_cash_cost_tickets t_1 (cost=0.28..8.30 rows=1 width=4)
Index Cond: (id = r_1.erp_cash_cost_ticket_id)
Filter: (is_payment_settle AND (status = ANY ('{2,5}'::integer[])))
-> Subquery Scan on "*SELECT* 3" (cost=0.28..55.14 rows=2 width=36)
-> Nested Loop (cost=0.28..55.12 rows=2 width=124)
-> Seq Scan on tbl_erp_payment_ticket_settles r_2 (cost=0.00..38.50 rows=2 width=12)
Filter: (sales_contract_id IS NOT NULL)
-> Index Scan using tbl_erp_payment_tickets_pkey on tbl_erp_payment_tickets t_2 (cost=0.28..8.30 rows=1 width=4)
Index Cond: (id = r_2.erp_payment_ticket_id)
Filter: (is_payment_settle AND (status = ANY ('{2,5}'::integer[])))
-> Hash (cost=64.37..64.37 rows=1637 width=4)
-> Seq Scan on tbl_sales_contracts t0 (cost=0.00..64.37 rows=1637 width=4)
-> Hash (cost=752.37..752.37 rows=6 width=76)
-> Nested Loop Left Join (cost=742.49..752.37 rows=6 width=76)
Filter: ((c.sales_rep = ANY ('{1001,5049,5301,5022,5209,5026,5293,5309,5356,5329,5299,5303,5302,5332,5047,1026,5096,5070,5448,5420,1029,5037,5087,1008,5048,5043,5045,5230,5031,5088,5208,1003,5294,5357,5044,1030,5076,5300,5027,5089,5311,5066,5069,5364,1009,5295,1013,5128,5203,1025,5032,5075,1004,5072,5033,5359,5409,5412,5229,1005,5304,5449,5358,1006,5093}'::integer[])) OR (c.sales_rep IS NULL))
-> Hash Right Join (cost=742.21..747.13 rows=8 width=72)
Hash Cond: (t1.id = sc.id)
-> HashAggregate (cost=318.23..320.57 rows=187 width=36)
Group Key: t1.id
-> Hash Join (cost=129.18..317.29 rows=187 width=10)
Hash Cond: (p.id = t1.from_project)
-> Seq Scan on tbl_projects p (cost=0.00..180.19 rows=1623 width=4)
Filter: (project_status = 3)
-> Hash (cost=124.78..124.78 rows=352 width=14)
-> Hash Join (cost=44.92..124.78 rows=352 width=14)
Hash Cond: (t1.id = t0_1.contract_id)
-> Seq Scan on tbl_sales_contracts t1 (cost=0.00..64.37 rows=1596 width=8)
Filter: (need_analysis AND (from_project IS NOT NULL))
-> Hash (cost=40.41..40.41 rows=361 width=10)
-> Seq Scan on tbl_sales_contract_payment_collection_remind_dates t0_1 (cost=0.00..40.41 rows=361 width=10)
Filter: (((status = 1) AND (overdue_days IS NOT NULL)) OR ((status = 0) AND (remind_date <= '2025-12-18'::date)))
-> Hash (cost=423.89..423.89 rows=8 width=40)
-> Hash Right Join (cost=410.90..423.89 rows=8 width=40)
Hash Cond: (t0_2.contract_id = sc.id)
Filter: ((t0_2.status = 0) OR ((t0_2.id IS NULL) AND (sc.erp_un_settle_amount <> '0'::numeric)))
-> HashAggregate (cost=326.20..331.94 rows=574 width=67)
Group Key: t0_2.id
-> Hash Join (cost=132.84..324.77 rows=574 width=26)
Hash Cond: (p_1.id = t1_1.from_project)
-> Seq Scan on tbl_projects p_1 (cost=0.00..180.19 rows=1623 width=4)
Filter: (project_status = 3)
-> Hash (cost=119.33..119.33 rows=1081 width=30)
-> Hash Join (cost=84.32..119.33 rows=1081 width=30)
Hash Cond: (t0_2.contract_id = t1_1.id)
-> Seq Scan on tbl_sales_contract_payment_collection_remind_dates t0_2 (cost=0.00..32.09 rows=1109 width=26)
-> Hash (cost=64.37..64.37 rows=1596 width=8)
-> Seq Scan on tbl_sales_contracts t1_1 (cost=0.00..64.37 rows=1596 width=8)
Filter: (need_analysis AND (from_project IS NOT NULL))
-> Hash (cost=64.37..64.37 rows=1626 width=25)
-> Seq Scan on tbl_sales_contracts sc (cost=0.00..64.37 rows=1626 width=25)
Filter: build_by_project
-> Index Scan using tbl_clients_pkey on tbl_clients c (cost=0.28..0.56 rows=1 width=8)
Index Cond: (sc.client_id = id)
-> Hash (cost=1.49..1.49 rows=49 width=4)
-> Seq Scan on tbl_sales_group_relationships sgr (cost=0.00..1.49 rows=49 width=4)