| Aggregate (cost=63.19..63.20 rows=1 width=32) |
| -> Append (cost=25.11..63.19 rows=2 width=32) |
| -> Aggregate (cost=25.11..25.12 rows=1 width=32) |
| -> Nested Loop (cost=13.17..25.11 rows=1 width=32) |
| Join Filter: (t.id = am.erp_other_income_ticket_id) |
| -> Nested Loop Left Join (cost=13.17..23.90 rows=1 width=4) |
| Filter: ((NOT (hashed SubPlan 1)) OR (t.sales_contract_id IS NULL)) |
| -> Seq Scan on tbl_erp_other_income_tickets t (cost=0.00..2.70 rows=1 width=8) |
| Filter: ((created_at >= '2025-04-01 00:00:00+08'::timestamp with time zone) AND (created_at <= '2025-04-30 23:59:59+08'::timestamp with time zone) AND (status = 2)) |
| -> Index Scan using tbl_sales_contracts_pkey on tbl_sales_contracts sc (cost=0.28..8.29 rows=1 width=8) |
| Index Cond: (id = t.sales_contract_id) |
| SubPlan 1 |
| -> Group (cost=12.88..12.89 rows=1 width=4) |
| Group Key: t_3.project_id |
| -> Sort (cost=12.88..12.89 rows=1 width=4) |
| Sort Key: t_3.project_id |
| -> Seq Scan on tbl_erp_profit_distributes t_3 (cost=0.00..12.88 rows=1 width=4) |
| Filter: ((project_id IS NOT NULL) AND (status = 2)) |
| -> Seq Scan on tbl_erp_other_income_ticket_handlers am (cost=0.00..1.09 rows=9 width=36) |
| -> Aggregate (cost=38.04..38.05 rows=1 width=32) |
| -> Nested Loop (cost=13.19..38.03 rows=1 width=11) |
| Join Filter: (pd.id = am_1.erp_profit_distribute_id) |
| -> Nested Loop (cost=13.19..36.85 rows=1 width=10) |
| Join Filter: (pd.project_id = sc_1.from_project) |
| -> Hash Join (cost=12.91..25.83 rows=1 width=12) |
| Hash Cond: (pd.project_id = t_2.project_id) |
| -> Seq Scan on tbl_erp_profit_distributes pd (cost=0.00..12.30 rows=230 width=8) |
| -> Hash (cost=12.90..12.90 rows=1 width=4) |
| -> Group (cost=12.88..12.89 rows=1 width=4) |
| Group Key: t_2.project_id |
| -> Sort (cost=12.88..12.89 rows=1 width=4) |
| Sort Key: t_2.project_id |
| -> Seq Scan on tbl_erp_profit_distributes t_2 (cost=0.00..12.88 rows=1 width=4) |
| Filter: ((project_id IS NOT NULL) AND (status = 2)) |
| -> Nested Loop (cost=0.28..11.00 rows=1 width=10) |
| -> Seq Scan on tbl_erp_other_income_tickets t_1 (cost=0.00..2.70 rows=1 width=10) |
| Filter: ((created_at >= '2025-04-01 00:00:00+08'::timestamp with time zone) AND (created_at <= '2025-04-30 23:59:59+08'::timestamp with time zone) AND (status = 2)) |
| -> Index Scan using tbl_sales_contracts_pkey on tbl_sales_contracts sc_1 (cost=0.28..8.29 rows=1 width=8) |
| Index Cond: (id = t_1.sales_contract_id) |
| -> Seq Scan on tbl_erp_profit_distribute_pcts am_1 (cost=0.00..1.08 rows=8 width=9) |