q75.sql 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. WITH all_sales AS (
  2. SELECT
  3. d_year,
  4. i_brand_id,
  5. i_class_id,
  6. i_category_id,
  7. i_manufact_id,
  8. SUM(sales_cnt) AS sales_cnt,
  9. SUM(sales_amt) AS sales_amt
  10. FROM (
  11. SELECT
  12. d_year,
  13. i_brand_id,
  14. i_class_id,
  15. i_category_id,
  16. i_manufact_id,
  17. cs_quantity - COALESCE(cr_return_quantity, 0) AS sales_cnt,
  18. cs_ext_sales_price - COALESCE(cr_return_amount, 0.0) AS sales_amt
  19. FROM catalog_sales
  20. JOIN item ON i_item_sk = cs_item_sk
  21. JOIN date_dim ON d_date_sk = cs_sold_date_sk
  22. LEFT JOIN catalog_returns ON (cs_order_number = cr_order_number
  23. AND cs_item_sk = cr_item_sk)
  24. WHERE i_category = 'Books'
  25. UNION
  26. SELECT
  27. d_year,
  28. i_brand_id,
  29. i_class_id,
  30. i_category_id,
  31. i_manufact_id,
  32. ss_quantity - COALESCE(sr_return_quantity, 0) AS sales_cnt,
  33. ss_ext_sales_price - COALESCE(sr_return_amt, 0.0) AS sales_amt
  34. FROM store_sales
  35. JOIN item ON i_item_sk = ss_item_sk
  36. JOIN date_dim ON d_date_sk = ss_sold_date_sk
  37. LEFT JOIN store_returns ON (ss_ticket_number = sr_ticket_number
  38. AND ss_item_sk = sr_item_sk)
  39. WHERE i_category = 'Books'
  40. UNION
  41. SELECT
  42. d_year,
  43. i_brand_id,
  44. i_class_id,
  45. i_category_id,
  46. i_manufact_id,
  47. ws_quantity - COALESCE(wr_return_quantity, 0) AS sales_cnt,
  48. ws_ext_sales_price - COALESCE(wr_return_amt, 0.0) AS sales_amt
  49. FROM web_sales
  50. JOIN item ON i_item_sk = ws_item_sk
  51. JOIN date_dim ON d_date_sk = ws_sold_date_sk
  52. LEFT JOIN web_returns ON (ws_order_number = wr_order_number
  53. AND ws_item_sk = wr_item_sk)
  54. WHERE i_category = 'Books') sales_detail
  55. GROUP BY d_year, i_brand_id, i_class_id, i_category_id, i_manufact_id)
  56. SELECT
  57. prev_yr.d_year AS prev_year,
  58. curr_yr.d_year AS year,
  59. curr_yr.i_brand_id,
  60. curr_yr.i_class_id,
  61. curr_yr.i_category_id,
  62. curr_yr.i_manufact_id,
  63. prev_yr.sales_cnt AS prev_yr_cnt,
  64. curr_yr.sales_cnt AS curr_yr_cnt,
  65. curr_yr.sales_cnt - prev_yr.sales_cnt AS sales_cnt_diff,
  66. curr_yr.sales_amt - prev_yr.sales_amt AS sales_amt_diff
  67. FROM all_sales curr_yr, all_sales prev_yr
  68. WHERE curr_yr.i_brand_id = prev_yr.i_brand_id
  69. AND curr_yr.i_class_id = prev_yr.i_class_id
  70. AND curr_yr.i_category_id = prev_yr.i_category_id
  71. AND curr_yr.i_manufact_id = prev_yr.i_manufact_id
  72. AND curr_yr.d_year = 2002
  73. AND prev_yr.d_year = 2002 - 1
  74. AND CAST(curr_yr.sales_cnt AS DECIMAL(17, 2)) / CAST(prev_yr.sales_cnt AS DECIMAL(17, 2)) < 0.9
  75. ORDER BY sales_cnt_diff
  76. LIMIT 100