QUERY PLAN
GroupAggregate (cost=589.23..590.70 rows=21 width=148)
Group Key: ex.id, sub.product_type
Filter: (sum(sub.amount) <> '0'::numeric)
-> Sort (cost=589.23..589.28 rows=21 width=116)
Sort Key: ex.id, sub.product_type
-> Hash Right Join (cost=586.96..588.77 rows=21 width=116)
Hash Cond: (ex.id = sub.product_type)
-> Seq Scan on tbl_product_types ex (cost=0.00..1.63 rows=63 width=16)
-> Hash (cost=586.70..586.70 rows=21 width=100)
-> Subquery Scan on sub (cost=586.12..586.70 rows=21 width=100)
-> HashAggregate (cost=586.12..586.49 rows=21 width=100)
Group Key: p.product_type
-> Hash Left Join (cost=506.60..584.54 rows=158 width=100)
Hash Cond: (p.id = sub_1.product_id)
-> Seq Scan on tbl_products p (cost=0.00..77.53 rows=158 width=8)
Filter: (product_brand = 4)
-> Hash (cost=506.55..506.55 rows=4 width=100)
-> Subquery Scan on sub_1 (cost=506.39..506.55 rows=4 width=100)
-> GroupAggregate (cost=506.39..506.51 rows=4 width=100)
Group Key: esosps.product_id
-> Sort (cost=506.39..506.40 rows=4 width=19)
Sort Key: esosps.product_id
-> Nested Loop (cost=104.13..506.35 rows=4 width=19)
Join Filter: (esosps.erp_sales_outbound_id = t.id)
-> Hash Join (cost=87.12..468.13 rows=1 width=4)
Hash Cond: (project.id = t.project_id)
-> Bitmap Heap Scan on tbl_projects project (cost=79.37..460.22 rows=24 width=4)
Recheck Cond: (created_by = ANY ('{1001,5049,5500,5301,5499,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,5467,5294,5357,5044,1030,5076,5300,5027,5089,5311,5066,5069,5364,1009,5295,1013,5128,5203,1025,5032,5075,5476,1004,5072,5033,5359,5412,5409,5229,1005,5304,5449,5358,1006,5093}'::integer[]))
Filter: ((bargain_date >= '2026-01-01'::date) AND (bargain_date <= '2026-12-31'::date) AND (((budget > collected) AND (project_status = ANY ('{3,-1}'::integer[]))) OR ((budget <= collected) AND (project_status = 3))))
-> Bitmap Index Scan on tbl_projects_created_by_idx (cost=0.00..79.36 rows=2111 width=0)
Index Cond: (created_by = ANY ('{1001,5049,5500,5301,5499,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,5467,5294,5357,5044,1030,5076,5300,5027,5089,5311,5066,5069,5364,1009,5295,1013,5128,5203,1025,5032,5075,5476,1004,5072,5033,5359,5412,5409,5229,1005,5304,5449,5358,1006,5093}'::integer[]))
-> Hash (cost=5.92..5.92 rows=146 width=8)
-> Seq Scan on tbl_erp_sales_outbounds t (cost=0.00..5.92 rows=146 width=8)
Filter: (status = 2)
-> Hash Right Join (cost=17.02..31.16 rows=565 width=23)
Hash Cond: (eipss.erp_sales_outbound_spent_product_id = esosps.id)
-> Seq Scan on tbl_erp_inventory_product_spents eipss (cost=0.00..12.65 rows=565 width=14)
-> Hash (cost=10.34..10.34 rows=534 width=17)
-> Seq Scan on tbl_erp_sales_outbound_spent_products esosps (cost=0.00..10.34 rows=534 width=17)