コンテストの制限時間が終了しました。
以降も提出を行うことができますが、順位集計には反映されません。
以降も提出を行うことができますが、順位集計には反映されません。
ソースコード
WITH WEEKDAYS AS (
SELECT '0' AS WEEKDAY, '日' AS WEEK UNION ALL
SELECT '1', '月' UNION ALL
SELECT '2', '火' UNION ALL
SELECT '3', '水' UNION ALL
SELECT '4', '木' UNION ALL
SELECT '5', '金' UNION ALL
SELECT '6', '土'
)
SELECT
WEEKDAYS.WEEK AS WEEK,
IFNULL(ROUND(COUNT(SALES_NO) * 1.0 / COUNT(DISTINCT strftime('%Y-%m-%d', SALES_DATE))), 0) AS AVG_CNT,
CASE
WHEN AVG_AMT_INT >= 1000000 THEN SUBSTR(AVG_AMT_INT, 1, LENGTH(AVG_AMT_INT) - 6) || ',' || SUBSTR(AVG_AMT_INT, LENGTH(AVG_AMT_INT) - 5, 3) || ',' || SUBSTR(AVG_AMT_INT, LENGTH(AVG_AMT_INT) - 2, 3)
WHEN AVG_AMT_INT >= 1000 THEN SUBSTR(AVG_AMT_INT, 1, LENGTH(AVG_AMT_INT) - 3) || ',' || SUBSTR(AVG_AMT_INT, LENGTH(AVG_AMT_INT) - 2, 3)
ELSE IFNULL(AVG_AMT_INT, 0)
END || '円' AS AVG_AMT
FROM
WEEKDAYS
LEFT JOIN
(
SELECT
SALES_DATE,
SALES_TYPE,
UPDATED_NO,
SALES_NO,
SALES_AMT,
CAST(ROUND(SUM(SALES_AMT) * 1.0 / COUNT(DISTINCT strftime('%Y-%m-%d', SALES_DATE))) AS INTEGER) AS AVG_AMT_INT
FROM
SALES
GROUP BY
strftime('%w', SALES_DATE)
) AS SALES
ON
WEEKDAYS.WEEKDAY = strftime('%w', SALES.SALES_DATE)
AND SALES_DATE BETWEEN '2024-03-01' AND '2024-03-28'
AND SALES_TYPE != 2
AND UPDATED_NO IS NULL
GROUP BY
WEEKDAYS.WEEKDAY
ORDER BY
WEEKDAYS.WEEKDAY;
提出情報
提出日時 | 2024/06/10 03:32:23 |
コンテスト | 第12回 SQLコンテスト |
問題 | 曜日別売上分析 |
受験者 | P128F |
状態 (詳細) | WA (Wrong Answer: 誤答) |
メモリ使用量 | 84 MB |
メッセージ
テストケース(通過数/総数)
0/2
状態
メモリ使用量
データパターン1
WA
84 MB
データパターン2
WA
84 MB