コンテストの制限時間が終了しました。
以降も提出を行うことができますが、順位集計には反映されません。
以降も提出を行うことができますが、順位集計には反映されません。
ソースコード
WITH total_sales AS (
SELECT
SUM(sd.UNITPRICE * sd.SALES_QTY) AS total_sales_amt
FROM
SALES s
JOIN SALES_DTL sd ON s.SALES_NO = sd.SALES_NO
WHERE
s.SALES_DATE BETWEEN '2023-06-01' AND '2023-06-30'
),
sales_data AS (
SELECT
i.ITEM_CODE AS CODE,
i.ITEM_NAME AS NAME,
sd.UNITPRICE * sd.SALES_QTY AS SAL_AMT
FROM
SALES s
JOIN SALES_DTL sd ON s.SALES_NO = sd.SALES_NO
JOIN ITEM i ON sd.ITEM_CODE = i.ITEM_CODE
WHERE
s.SALES_DATE BETWEEN '2023-06-01' AND '2023-06-30'
),
sales_data_with_comp AS (
SELECT
sd.*,
((sd.SAL_AMT * 1.0) / total_sales.total_sales_amt) * 100 AS SAL_COMP
FROM
sales_data sd
CROSS JOIN total_sales
),
sales_data_with_rank AS (
SELECT
sd.*,
SUM(SAL_COMP) OVER (
ORDER BY
SAL_AMT DESC,
CODE DESC
ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
) AS TTL_COMP
FROM
sales_data_with_comp sd
)
SELECT
sdw.CODE,
sdw.NAME,
sdw.SAL_AMT,
sdw.SAL_AMT * (sdw.TTL_COMP / 100) AS CML_AMT,
printf("%.1f%%", sdw.SAL_COMP) AS SAL_COMP,
printf("%.1f%%", sdw.TTL_COMP) AS TTL_COMP,
CASE
WHEN sdw.TTL_COMP <= 40 THEN 'A'
WHEN sdw.TTL_COMP <= 80 THEN 'B'
ELSE 'C'
END AS RANK
FROM
sales_data_with_rank sdw
ORDER BY
sdw.SAL_AMT DESC,
sdw.CODE DESC;
提出情報
提出日時 | 2023/06/16 13:39:55 |
コンテスト | 第7回 SQLコンテスト |
問題 | ABC分析 |
受験者 | inuinu |
状態 (詳細) | WA (Wrong Answer: 誤答) |
メモリ使用量 | 89 MB |
メッセージ
テストケース(通過数/総数)
0/3
状態
メモリ使用量
データパターン1
WA
78 MB
データパターン2
WA
89 MB
データパターン3
WA
88 MB