q78.sql 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. WITH ws AS
  2. (SELECT
  3. d_year AS ws_sold_year,
  4. ws_item_sk,
  5. ws_bill_customer_sk ws_customer_sk,
  6. sum(ws_quantity) ws_qty,
  7. sum(ws_wholesale_cost) ws_wc,
  8. sum(ws_sales_price) ws_sp
  9. FROM web_sales
  10. LEFT JOIN web_returns ON wr_order_number = ws_order_number AND ws_item_sk = wr_item_sk
  11. JOIN date_dim ON ws_sold_date_sk = d_date_sk
  12. WHERE wr_order_number IS NULL
  13. GROUP BY d_year, ws_item_sk, ws_bill_customer_sk
  14. ),
  15. cs AS
  16. (SELECT
  17. d_year AS cs_sold_year,
  18. cs_item_sk,
  19. cs_bill_customer_sk cs_customer_sk,
  20. sum(cs_quantity) cs_qty,
  21. sum(cs_wholesale_cost) cs_wc,
  22. sum(cs_sales_price) cs_sp
  23. FROM catalog_sales
  24. LEFT JOIN catalog_returns ON cr_order_number = cs_order_number AND cs_item_sk = cr_item_sk
  25. JOIN date_dim ON cs_sold_date_sk = d_date_sk
  26. WHERE cr_order_number IS NULL
  27. GROUP BY d_year, cs_item_sk, cs_bill_customer_sk
  28. ),
  29. ss AS
  30. (SELECT
  31. d_year AS ss_sold_year,
  32. ss_item_sk,
  33. ss_customer_sk,
  34. sum(ss_quantity) ss_qty,
  35. sum(ss_wholesale_cost) ss_wc,
  36. sum(ss_sales_price) ss_sp
  37. FROM store_sales
  38. LEFT JOIN store_returns ON sr_ticket_number = ss_ticket_number AND ss_item_sk = sr_item_sk
  39. JOIN date_dim ON ss_sold_date_sk = d_date_sk
  40. WHERE sr_ticket_number IS NULL
  41. GROUP BY d_year, ss_item_sk, ss_customer_sk
  42. )
  43. SELECT
  44. round(ss_qty / (coalesce(ws_qty + cs_qty, 1)), 2) ratio,
  45. ss_qty store_qty,
  46. ss_wc store_wholesale_cost,
  47. ss_sp store_sales_price,
  48. coalesce(ws_qty, 0) + coalesce(cs_qty, 0) other_chan_qty,
  49. coalesce(ws_wc, 0) + coalesce(cs_wc, 0) other_chan_wholesale_cost,
  50. coalesce(ws_sp, 0) + coalesce(cs_sp, 0) other_chan_sales_price
  51. FROM ss
  52. LEFT JOIN ws
  53. ON (ws_sold_year = ss_sold_year AND ws_item_sk = ss_item_sk AND ws_customer_sk = ss_customer_sk)
  54. LEFT JOIN cs
  55. ON (cs_sold_year = ss_sold_year AND cs_item_sk = ss_item_sk AND cs_customer_sk = ss_customer_sk)
  56. WHERE coalesce(ws_qty, 0) > 0 AND coalesce(cs_qty, 0) > 0 AND ss_sold_year = 2000
  57. ORDER BY
  58. ratio,
  59. ss_qty DESC, ss_wc DESC, ss_sp DESC,
  60. other_chan_qty,
  61. other_chan_wholesale_cost,
  62. other_chan_sales_price,
  63. round(ss_qty / (coalesce(ws_qty + cs_qty, 1)), 2)
  64. LIMIT 100