q02.sql 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. --!syntax_pg
  2. --TPC-DS Q2
  3. -- start query 1 in stream 0 using template ../query_templates/query2.tpl
  4. with wscs as
  5. (select sold_date_sk
  6. ,sales_price
  7. from (select ws_sold_date_sk sold_date_sk
  8. ,ws_ext_sales_price sales_price
  9. from plato.web_sales
  10. union all
  11. select cs_sold_date_sk sold_date_sk
  12. ,cs_ext_sales_price sales_price
  13. from plato.catalog_sales) a),
  14. wswscs as
  15. (select d_week_seq,
  16. sum(case when (d_day_name='Sunday') then sales_price else null::numeric end) sun_sales,
  17. sum(case when (d_day_name='Monday') then sales_price else null::numeric end) mon_sales,
  18. sum(case when (d_day_name='Tuesday') then sales_price else null::numeric end) tue_sales,
  19. sum(case when (d_day_name='Wednesday') then sales_price else null::numeric end) wed_sales,
  20. sum(case when (d_day_name='Thursday') then sales_price else null::numeric end) thu_sales,
  21. sum(case when (d_day_name='Friday') then sales_price else null::numeric end) fri_sales,
  22. sum(case when (d_day_name='Saturday') then sales_price else null::numeric end) sat_sales
  23. from wscs
  24. ,plato.date_dim
  25. where d_date_sk = sold_date_sk
  26. group by d_week_seq)
  27. select d_week_seq1
  28. ,round(sun_sales1/sun_sales2,2) r1
  29. ,round(mon_sales1/mon_sales2,2) r2
  30. ,round(tue_sales1/tue_sales2,2) r3
  31. ,round(wed_sales1/wed_sales2,2) r4
  32. ,round(thu_sales1/thu_sales2,2) r5
  33. ,round(fri_sales1/fri_sales2,2) r6
  34. ,round(sat_sales1/sat_sales2,2) r7
  35. from
  36. (select wswscs.d_week_seq d_week_seq1
  37. ,sun_sales sun_sales1
  38. ,mon_sales mon_sales1
  39. ,tue_sales tue_sales1
  40. ,wed_sales wed_sales1
  41. ,thu_sales thu_sales1
  42. ,fri_sales fri_sales1
  43. ,sat_sales sat_sales1
  44. from wswscs,plato.date_dim
  45. where date_dim.d_week_seq = wswscs.d_week_seq and
  46. d_year = 2001) y,
  47. (select wswscs.d_week_seq d_week_seq2
  48. ,sun_sales sun_sales2
  49. ,mon_sales mon_sales2
  50. ,tue_sales tue_sales2
  51. ,wed_sales wed_sales2
  52. ,thu_sales thu_sales2
  53. ,fri_sales fri_sales2
  54. ,sat_sales sat_sales2
  55. from wswscs
  56. ,plato.date_dim
  57. where date_dim.d_week_seq = wswscs.d_week_seq and
  58. d_year = 2001+1) z
  59. where d_week_seq1=d_week_seq2-53
  60. order by d_week_seq1;
  61. -- end query 1 in stream 0 using template ../query_templates/query2.tpl