q72.sql 1.4 KB

1234567891011121314151617181920212223242526272829303132
  1. --!syntax_pg
  2. --TPC-DS Q72
  3. -- start query 1 in stream 0 using template ../query_templates/query72.tpl
  4. select i_item_desc
  5. ,w_warehouse_name
  6. ,d1.d_week_seq
  7. ,sum(case when p_promo_sk is null then 1 else 0 end) no_promo
  8. ,sum(case when p_promo_sk is not null then 1 else 0 end) promo
  9. ,count(*) total_cnt
  10. from plato.catalog_sales
  11. join plato.inventory on (cs_item_sk = inv_item_sk)
  12. join plato.warehouse on (w_warehouse_sk=inv_warehouse_sk)
  13. join plato.item on (i_item_sk = cs_item_sk)
  14. join plato.customer_demographics on (cs_bill_cdemo_sk = cd_demo_sk)
  15. join plato.household_demographics on (cs_bill_hdemo_sk = hd_demo_sk)
  16. join plato.date_dim d1 on (cs_sold_date_sk = d1.d_date_sk)
  17. join plato.date_dim d2 on (inv_date_sk = d2.d_date_sk)
  18. join plato.date_dim d3 on (cs_ship_date_sk = d3.d_date_sk)
  19. left outer join plato.promotion on (cs_promo_sk=p_promo_sk)
  20. left outer join plato.catalog_returns on (cr_item_sk = cs_item_sk and cr_order_number = cs_order_number)
  21. where d1.d_week_seq = d2.d_week_seq
  22. and inv_quantity_on_hand < cs_quantity
  23. and d3.d_date > d1.d_date + 5
  24. and hd_buy_potential = '1001-5000'
  25. and d1.d_year = 2001
  26. and cd_marital_status = 'M'
  27. group by i_item_desc,w_warehouse_name,d1.d_week_seq
  28. order by total_cnt desc, i_item_desc, w_warehouse_name, d_week_seq
  29. limit 100;
  30. -- end query 1 in stream 0 using template ../query_templates/query72.tpl