QUERY PLAN
Limit (cost=234.10..234.15 rows=20 width=422)
-> Sort (cost=234.10..234.23 rows=53 width=422)
Sort Key: r.wrote_date DESC
-> Append (cost=35.43..232.69 rows=53 width=422)
-> GroupAggregate (cost=35.43..35.48 rows=1 width=407)
Group Key: r.id
-> Sort (cost=35.43..35.43 rows=1 width=102)
Sort Key: r.id
-> Nested Loop Left Join (cost=12.78..35.42 rows=1 width=102)
-> Nested Loop (cost=12.66..35.22 rows=1 width=95)
-> Hash Right Join (cost=12.51..26.98 rows=1 width=32)
Hash Cond: (eip.erp_purchase_inbound_product_id = rp.id)
-> Seq Scan on tbl_erp_inventory_products eip (cost=0.00..13.11 rows=511 width=11)
-> Hash (cost=12.50..12.50 rows=1 width=29)
-> Seq Scan on tbl_erp_purchase_inbound_products rp (cost=0.00..12.50 rows=1 width=29)
Filter: (product_id = 867)
-> Index Scan using tbl_erp_purchase_inbounds_pkey on tbl_erp_purchase_inbounds r (cost=0.14..8.16 rows=1 width=67)
Index Cond: (id = rp.erp_purchase_inbound_id)
Filter: (status = ANY ('{2,5}'::integer[]))
-> Index Scan using tbl_erp_stores_pkey on tbl_erp_stores s (cost=0.13..0.17 rows=1 width=15)
Index Cond: (eip.erp_store_id = id)
-> GroupAggregate (cost=10.62..25.22 rows=1 width=471)
Group Key: r_1.id
-> Nested Loop Left Join (cost=10.62..25.19 rows=1 width=152)
-> Nested Loop Left Join (cost=10.49..24.99 rows=1 width=145)
-> Merge Join (cost=2.18..2.22 rows=1 width=145)
Merge Cond: (r_1.id = rp_1.erp_purchase_return_id)
-> Sort (cost=1.10..1.11 rows=3 width=131)
Sort Key: r_1.id
-> Seq Scan on tbl_erp_purchase_returns r_1 (cost=0.00..1.07 rows=3 width=131)
Filter: (status = ANY ('{2,5}'::integer[]))
-> Sort (cost=1.08..1.09 rows=1 width=18)
Sort Key: rp_1.erp_purchase_return_id
-> Seq Scan on tbl_erp_purchase_return_products rp_1 (cost=0.00..1.07 rows=1 width=18)
Filter: (product_id = 867)
-> Hash Right Join (cost=8.30..22.77 rows=1 width=8)
Hash Cond: (eip_1.erp_purchase_inbound_product_id = epip.id)
-> Seq Scan on tbl_erp_inventory_products eip_1 (cost=0.00..13.11 rows=511 width=8)
-> Hash (cost=8.29..8.29 rows=1 width=4)
-> Index Only Scan using tbl_erp_purchase_inbound_products_pkey on tbl_erp_purchase_inbound_products epip (cost=0.28..8.29 rows=1 width=4)
Index Cond: (id = rp_1.erp_purchase_inbound_product_id)
-> Index Scan using tbl_erp_stores_pkey on tbl_erp_stores s_1 (cost=0.13..0.17 rows=1 width=15)
Index Cond: (eip_1.erp_store_id = id)
-> GroupAggregate (cost=2.87..11.04 rows=1 width=407)
Group Key: r_2.id
-> Nested Loop Left Join (cost=2.87..11.01 rows=1 width=75)
-> Merge Join (cost=2.47..2.52 rows=1 width=68)
Merge Cond: (r_2.id = rp_2.erp_inventory_lost_id)
-> Sort (cost=1.22..1.24 rows=7 width=59)
Sort Key: r_2.id
-> Seq Scan on tbl_erp_inventory_losts r_2 (cost=0.00..1.12 rows=7 width=59)
Filter: (status = ANY ('{1,2,5}'::integer[]))
-> Sort (cost=1.25..1.25 rows=1 width=13)
Sort Key: rp_2.erp_inventory_lost_id
-> Seq Scan on tbl_erp_inventory_lost_products rp_2 (cost=0.00..1.24 rows=1 width=13)
Filter: (product_id = 867)
-> Nested Loop Left Join (cost=0.40..8.49 rows=1 width=15)
-> Index Scan using tbl_erp_inventory_products_pkey on tbl_erp_inventory_products eip_2 (cost=0.27..8.29 rows=1 width=8)
Index Cond: (id = rp_2.erp_inventory_product_id)
-> Index Scan using tbl_erp_stores_pkey on tbl_erp_stores s_2 (cost=0.13..0.17 rows=1 width=15)
Index Cond: (eip_2.erp_store_id = id)
-> GroupAggregate (cost=20.86..22.13 rows=10 width=401)
Group Key: r_3.id
-> Merge Left Join (cost=20.86..21.76 rows=10 width=285)
Merge Cond: (r_3.id = rp_3.erp_inventory_build_id)
Filter: ((rp_3.erp_inventory_build_id IS NOT NULL) OR (build_out.erp_inventory_build_id IS NOT NULL))
-> Sort (cost=2.56..2.59 rows=10 width=129)
Sort Key: r_3.id
-> Hash Left Join (cost=1.19..2.40 rows=10 width=129)
Hash Cond: (r_3.id = build_out.erp_inventory_build_id)
-> Seq Scan on tbl_erp_inventory_builds r_3 (cost=0.00..1.17 rows=10 width=61)
Filter: (status = ANY ('{1,2,5}'::integer[]))
-> Hash (cost=1.18..1.18 rows=1 width=68)
-> Subquery Scan on build_out (cost=1.16..1.18 rows=1 width=68)
-> HashAggregate (cost=1.16..1.17 rows=1 width=68)
Group Key: tbl_erp_inventory_build_spent_products.erp_inventory_build_id
-> Seq Scan on tbl_erp_inventory_build_spent_products (cost=0.00..1.15 rows=1 width=14)
Filter: (product_id = 867)
-> Materialize (cost=18.29..19.13 rows=1 width=164)
-> GroupAggregate (cost=18.29..19.12 rows=1 width=164)
Group Key: rp_3.erp_inventory_build_id
-> Sort (cost=18.29..18.41 rows=46 width=32)
Sort Key: rp_3.erp_inventory_build_id
-> Hash Left Join (cost=2.19..17.02 rows=46 width=32)
Hash Cond: (eip_3.erp_store_id = s_3.id)
-> Hash Right Join (cost=1.15..15.60 rows=46 width=25)
Hash Cond: (eip_3.erp_inventory_build_product_id = rp_3.id)
-> Seq Scan on tbl_erp_inventory_products eip_3 (cost=0.00..13.11 rows=511 width=25)
-> Hash (cost=1.14..1.14 rows=1 width=8)
-> Seq Scan on tbl_erp_inventory_build_products rp_3 (cost=0.00..1.14 rows=1 width=8)
Filter: (product_id = 867)
-> Hash (cost=1.02..1.02 rows=2 width=15)
-> Seq Scan on tbl_erp_stores s_3 (cost=0.00..1.02 rows=2 width=15)
-> GroupAggregate (cost=21.28..22.62 rows=4 width=456)
Group Key: r_4.id
-> Merge Left Join (cost=21.28..22.47 rows=4 width=340)
Merge Cond: (r_4.id = rp_4.erp_inventory_disassemble_id)
Filter: ((rp_4.erp_inventory_disassemble_id IS NOT NULL) OR (disassemble_out.erp_inventory_disassemble_id IS NOT NULL))
-> Sort (cost=2.23..2.24 rows=4 width=184)
Sort Key: r_4.id
-> Hash Left Join (cost=1.09..2.19 rows=4 width=184)
Hash Cond: (r_4.id = disassemble_out.erp_inventory_disassemble_id)
-> Seq Scan on tbl_erp_inventory_disassembles r_4 (cost=0.00..1.07 rows=4 width=116)
Filter: (status = ANY ('{1,2,5}'::integer[]))
-> Hash (cost=1.08..1.08 rows=1 width=68)
-> Subquery Scan on disassemble_out (cost=1.06..1.08 rows=1 width=68)
-> HashAggregate (cost=1.06..1.07 rows=1 width=68)
Group Key: tbl_erp_inventory_disassemble_spent_products.erp_inventory_disassemble_id
-> Seq Scan on tbl_erp_inventory_disassemble_spent_products (cost=0.00..1.05 rows=1 width=14)
Filter: (product_id = 867)
-> Materialize (cost=19.05..20.21 rows=1 width=164)
-> GroupAggregate (cost=19.05..20.20 rows=1 width=164)
Group Key: rp_4.erp_inventory_disassemble_id
-> Sort (cost=19.05..19.21 rows=64 width=32)
Sort Key: rp_4.erp_inventory_disassemble_id
-> Hash Left Join (cost=2.16..17.13 rows=64 width=32)
Hash Cond: (eip_4.erp_store_id = s_4.id)
-> Hash Right Join (cost=1.11..15.56 rows=64 width=25)
Hash Cond: (eip_4.erp_inventory_disassemble_product_id = rp_4.id)
-> Seq Scan on tbl_erp_inventory_products eip_4 (cost=0.00..13.11 rows=511 width=25)
-> Hash (cost=1.10..1.10 rows=1 width=8)
-> Seq Scan on tbl_erp_inventory_disassemble_products rp_4 (cost=0.00..1.10 rows=1 width=8)
Filter: (product_id = 867)
-> Hash (cost=1.02..1.02 rows=2 width=15)
-> Seq Scan on tbl_erp_stores s_4 (cost=0.00..1.02 rows=2 width=15)
-> GroupAggregate (cost=19.29..19.79 rows=10 width=427)
Group Key: r_5.id
-> Sort (cost=19.29..19.31 rows=10 width=144)
Sort Key: r_5.id
-> Nested Loop Left Join (cost=3.36..19.12 rows=10 width=144)
Join Filter: (eip_5.erp_store_id = s_5.id)
-> Hash Join (cost=3.36..17.85 rows=10 width=137)
Hash Cond: (rp_5.erp_inventory_start_id = r_5.id)
-> Hash Right Join (cost=1.64..16.10 rows=10 width=58)
Hash Cond: (eip_5.erp_inventory_start_product_id = rp_5.id)
-> Seq Scan on tbl_erp_inventory_products eip_5 (cost=0.00..13.11 rows=511 width=11)
-> Hash (cost=1.62..1.62 rows=1 width=55)
-> Seq Scan on tbl_erp_inventory_start_products rp_5 (cost=0.00..1.62 rows=1 width=55)
Filter: (product_id = 867)
-> Hash (cost=1.32..1.32 rows=32 width=83)
-> Seq Scan on tbl_erp_inventory_starts r_5 (cost=0.00..1.32 rows=32 width=83)
-> Materialize (cost=0.00..1.03 rows=2 width=15)
-> Seq Scan on tbl_erp_stores s_5 (cost=0.00..1.02 rows=2 width=15)
-> GroupAggregate (cost=26.88..26.94 rows=1 width=457)
Group Key: r_6.id
-> Sort (cost=26.88..26.88 rows=1 width=148)
Sort Key: r_6.id
-> Nested Loop Left Join (cost=12.09..26.87 rows=1 width=148)
-> Hash Join (cost=11.69..18.37 rows=1 width=141)
Hash Cond: (r_6.id = rp_6.erp_sales_outbound_id)
-> Seq Scan on tbl_erp_sales_outbounds r_6 (cost=0.00..6.12 rows=149 width=117)
Filter: (status = ANY ('{1,2,5}'::integer[]))
-> Hash (cost=11.68..11.68 rows=1 width=28)
-> Seq Scan on tbl_erp_sales_outbound_spent_products rp_6 (cost=0.00..11.68 rows=1 width=28)
Filter: (product_id = 867)
-> Nested Loop Left Join (cost=0.40..8.49 rows=1 width=15)
-> Index Scan using tbl_erp_inventory_products_pkey on tbl_erp_inventory_products eip_6 (cost=0.27..8.29 rows=1 width=8)
Index Cond: (id = rp_6.erp_inventory_product_id)
-> Index Scan using tbl_erp_stores_pkey on tbl_erp_stores s_6 (cost=0.13..0.17 rows=1 width=15)
Index Cond: (eip_6.erp_store_id = id)
-> GroupAggregate (cost=2.88..11.15 rows=1 width=481)
Group Key: r_7.id
-> Nested Loop Left Join (cost=2.88..11.11 rows=1 width=163)
-> Nested Loop Left Join (cost=2.75..10.92 rows=1 width=156)
-> Merge Join (cost=2.20..2.23 rows=1 width=156)
Merge Cond: (r_7.id = rp_7.erp_sales_return_id)
-> Sort (cost=1.11..1.12 rows=4 width=141)
Sort Key: r_7.id
-> Seq Scan on tbl_erp_sales_returns r_7 (cost=0.00..1.07 rows=4 width=141)
Filter: (status = ANY ('{2,5}'::integer[]))
-> Sort (cost=1.08..1.09 rows=1 width=19)
Sort Key: rp_7.erp_sales_return_id
-> Seq Scan on tbl_erp_sales_return_products rp_7 (cost=0.00..1.07 rows=1 width=19)
Filter: (product_id = 867)
-> Nested Loop Left Join (cost=0.55..8.67 rows=1 width=8)
-> Index Scan using tbl_erp_sales_outbound_spent_products_pkey on tbl_erp_sales_outbound_spent_products rp2 (cost=0.28..8.29 rows=1 width=8)
Index Cond: (rp_7.erp_sales_outbound_spent_product_id = id)
-> Index Scan using tbl_erp_inventory_products_pkey on tbl_erp_inventory_products eip_7 (cost=0.27..0.38 rows=1 width=8)
Index Cond: (id = rp2.erp_inventory_product_id)
-> Index Scan using tbl_erp_stores_pkey on tbl_erp_stores s_7 (cost=0.13..0.17 rows=1 width=15)
Index Cond: (eip_7.erp_store_id = id)
-> GroupAggregate (cost=19.03..19.93 rows=17 width=409)
Group Key: r_8.id
-> Sort (cost=19.03..19.09 rows=22 width=97)
Sort Key: r_8.id
-> Hash Left Join (cost=3.83..18.54 rows=22 width=97)
Hash Cond: (eip_8.erp_store_id = s_8.id)
-> Hash Join (cost=2.79..17.32 rows=22 width=90)
Hash Cond: (rp_8.erp_purchase_gift_id = r_8.id)
-> Hash Right Join (cost=1.30..15.76 rows=22 width=25)
Hash Cond: (eip_8.erp_purchase_gift_product_id = rp_8.id)
-> Seq Scan on tbl_erp_inventory_products eip_8 (cost=0.00..13.11 rows=511 width=25)
-> Hash (cost=1.29..1.29 rows=1 width=8)
-> Seq Scan on tbl_erp_purchase_gift_products rp_8 (cost=0.00..1.29 rows=1 width=8)
Filter: (product_id = 867)
-> Hash (cost=1.27..1.27 rows=17 width=69)
-> Seq Scan on tbl_erp_purchase_gifts r_8 (cost=0.00..1.27 rows=17 width=69)
Filter: (status = ANY ('{2,5}'::integer[]))
-> Hash (cost=1.02..1.02 rows=2 width=15)
-> Seq Scan on tbl_erp_stores s_8 (cost=0.00..1.02 rows=2 width=15)
-> GroupAggregate (cost=19.26..20.07 rows=6 width=447)
Group Key: r_9.id
-> Sort (cost=19.26..19.35 rows=36 width=127)
Sort Key: r_9.id
-> Hash Left Join (cost=3.43..18.33 rows=36 width=127)
Hash Cond: (eip_9.erp_store_id = s_9.id)
-> Hash Join (cost=2.39..16.99 rows=36 width=120)
Hash Cond: (rp_9.erp_inventory_overflow_id = r_9.id)
-> Hash Right Join (cost=1.19..15.65 rows=36 width=25)
Hash Cond: (eip_9.erp_inventory_overflow_product_id = rp_9.id)
-> Seq Scan on tbl_erp_inventory_products eip_9 (cost=0.00..13.11 rows=511 width=25)
-> Hash (cost=1.18..1.18 rows=1 width=8)
-> Seq Scan on tbl_erp_inventory_overflow_products rp_9 (cost=0.00..1.18 rows=1 width=8)
Filter: (product_id = 867)
-> Hash (cost=1.12..1.12 rows=6 width=99)
-> Seq Scan on tbl_erp_inventory_overflows r_9 (cost=0.00..1.12 rows=6 width=99)
Filter: (status = ANY ('{2,5}'::integer[]))
-> Hash (cost=1.02..1.02 rows=2 width=15)
-> Seq Scan on tbl_erp_stores s_9 (cost=0.00..1.02 rows=2 width=15)
-> GroupAggregate (cost=17.75..17.79 rows=1 width=436)
Group Key: r_10.id
-> Sort (cost=17.75..17.76 rows=1 width=112)
Sort Key: r_10.id
-> Nested Loop Left Join (cost=4.40..17.74 rows=1 width=112)
-> Hash Join (cost=4.00..9.25 rows=1 width=105)
Hash Cond: (r_10.id = rp_10.erp_sales_gift_id)
-> Seq Scan on tbl_erp_sales_gifts r_10 (cost=0.00..4.77 rows=124 width=96)
Filter: (status = ANY ('{1,2,5}'::integer[]))
-> Hash (cost=3.99..3.99 rows=1 width=13)
-> Seq Scan on tbl_erp_sales_gift_spent_products rp_10 (cost=0.00..3.99 rows=1 width=13)
Filter: (product_id = 867)
-> Nested Loop Left Join (cost=0.40..8.49 rows=1 width=15)
-> Index Scan using tbl_erp_inventory_products_pkey on tbl_erp_inventory_products eip_10 (cost=0.27..8.29 rows=1 width=8)
Index Cond: (id = rp_10.erp_inventory_product_id)
-> Index Scan using tbl_erp_stores_pkey on tbl_erp_stores s_10 (cost=0.13..0.17 rows=1 width=15)
Index Cond: (eip_10.erp_store_id = id)