q59.sql 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. --!syntax_pg
  2. --TPC-DS Q59
  3. -- start query 1 in stream 0 using template ../query_templates/query59.tpl
  4. with wss as
  5. (select d_week_seq,
  6. ss_store_sk,
  7. sum(case when (d_day_name='Sunday') then ss_sales_price else null::numeric end) sun_sales,
  8. sum(case when (d_day_name='Monday') then ss_sales_price else null::numeric end) mon_sales,
  9. sum(case when (d_day_name='Tuesday') then ss_sales_price else null::numeric end) tue_sales,
  10. sum(case when (d_day_name='Wednesday') then ss_sales_price else null::numeric end) wed_sales,
  11. sum(case when (d_day_name='Thursday') then ss_sales_price else null::numeric end) thu_sales,
  12. sum(case when (d_day_name='Friday') then ss_sales_price else null::numeric end) fri_sales,
  13. sum(case when (d_day_name='Saturday') then ss_sales_price else null::numeric end) sat_sales
  14. from plato.store_sales,plato.date_dim
  15. where d_date_sk = ss_sold_date_sk
  16. group by d_week_seq,ss_store_sk
  17. )
  18. select s_store_name1,s_store_id1,d_week_seq1
  19. ,sun_sales1/sun_sales2,mon_sales1/mon_sales2
  20. ,tue_sales1/tue_sales2,wed_sales1/wed_sales2,thu_sales1/thu_sales2
  21. ,fri_sales1/fri_sales2,sat_sales1/sat_sales2
  22. from
  23. (select s_store_name s_store_name1,wss.d_week_seq d_week_seq1
  24. ,s_store_id s_store_id1,sun_sales sun_sales1
  25. ,mon_sales mon_sales1,tue_sales tue_sales1
  26. ,wed_sales wed_sales1,thu_sales thu_sales1
  27. ,fri_sales fri_sales1,sat_sales sat_sales1
  28. from wss,plato.store,plato.date_dim d
  29. where d.d_week_seq = wss.d_week_seq and
  30. ss_store_sk = s_store_sk and
  31. d_month_seq between 1185 and 1185 + 11) y,
  32. (select s_store_name s_store_name2,wss.d_week_seq d_week_seq2
  33. ,s_store_id s_store_id2,sun_sales sun_sales2
  34. ,mon_sales mon_sales2,tue_sales tue_sales2
  35. ,wed_sales wed_sales2,thu_sales thu_sales2
  36. ,fri_sales fri_sales2,sat_sales sat_sales2
  37. from wss,plato.store,plato.date_dim d
  38. where d.d_week_seq = wss.d_week_seq and
  39. ss_store_sk = s_store_sk and
  40. d_month_seq between 1185+ 12 and 1185 + 23) x
  41. where s_store_id1=s_store_id2
  42. and d_week_seq1=d_week_seq2-52
  43. order by s_store_name1,s_store_id1,d_week_seq1
  44. limit 100;
  45. -- end query 1 in stream 0 using template ../query_templates/query59.tpl