コンテストの制限時間が終了しました。
以降も提出を行うことができますが、順位集計には反映されません。
以降も提出を行うことができますが、順位集計には反映されません。
ソースコード
WITH
ranked_foreigner AS (
SELECT
-- primary
A.PF_CODE,
-- primary
A.NATION_CODE,
-- primary (NATION_CODE と同じ)
B.NATION_NAME,
A.AMT,
RANK() OVER (
PARTITION BY
A.PF_CODE
ORDER BY
A.AMT DESC,
A.PF_CODE ASC
) AS AMT_RANK
FROM FOREIGNER AS A
INNER JOIN NATIONALITY AS B
ON A.NATION_CODE = B.NATION_CODE
WHERE
A.NATION_CODE <> 113
),
-- どうやらその他を除いた合計で良いらしい
-- であれば、 ranked_foreigner で設定すれば良いが今回は治すの面倒なのでこっちで.
-- その他を含めた合計は `WHERE` の句を取り除いたもの
pf_total_amt_table AS (
SELECT
-- primary
A.PF_CODE,
SUM(A.AMT) AS total_amt
FROM FOREIGNER AS A
WHERE
A.NATION_CODE <> 113
GROUP BY
A.PF_CODE
),
table1 AS (
SELECT
-- primary
PF_CODE,
NATION_NAME,
AMT
FROM ranked_foreigner
WHERE
ranked_foreigner.AMT_RANK = 1
),
table2 AS (
SELECT
-- primary
PF_CODE,
NATION_NAME,
AMT
FROM
ranked_foreigner
WHERE
ranked_foreigner.AMT_RANK = 2
),
table3 AS (
SELECT
-- primary
PF_CODE,
NATION_NAME,
AMT
FROM
ranked_foreigner
WHERE
ranked_foreigner.AMT_RANK = 3
)
SELECT
A.PF_CODE as `都道府県コード`,
A.PF_NAME as `都道府県名`,
table1.NATION_NAME as `1位 国名`,
table1.AMT as `1位 人数`,
table2.NATION_NAME as `2位 国名`,
table2.AMT as `2位 人数`,
table3.NATION_NAME as `3位 国名`,
table3.AMT as `3位 人数`,
pf_total_amt_table.total_amt AS `合計人数`
FROM PREFECTURE AS A
INNER JOIN table1
ON A.PF_CODE = table1.PF_CODE
INNER JOIN table2
ON A.PF_CODE = table2.PF_CODE
INNER JOIN table3
ON A.PF_CODE = table3.PF_CODE
INNER JOIN pf_total_amt_table
ON A.PF_CODE = pf_total_amt_table.PF_CODE
ORDER BY
`合計人数` DESC,
A.PF_CODE ASC
;
提出情報
提出日時 | 2023/07/07 07:34:29 |
コンテスト | 第1回 SQLコンテスト |
問題 | 外国籍分布 |
受験者 | mazny |
状態 (詳細) | WA (Wrong Answer: 誤答) |
メモリ使用量 | 82 MB |
メッセージ
テストケース(通過数/総数)
1/2
状態
メモリ使用量
データパターン1
WA
82 MB
データパターン2
AC
77 MB