ソースコード
SELECT
    m.pf_code as "都道府県コード",
    m.pf_name as "都道府県名",
    MAX(CASE WHEN ranking = 1 THEN nation_name END) as "1位 国名",
    SUM(CASE WHEN ranking = 1 THEN amt ELSE 0 END) as "1位 人数",
    MAX(CASE WHEN ranking = 2 THEN nation_name END) as "2位 国名",
    SUM(CASE WHEN ranking = 2 THEN amt ELSE 0 END) as "2位 人数",
    MAX(CASE WHEN ranking = 3 THEN nation_name END) as "3位 国名",
    SUM(CASE WHEN ranking = 3 THEN amt ELSE 0 END) as "3位 人数",
    SUM(n.total) as "合計人数"
FROM (
    SELECT 
    f.pf_code,
    p.pf_name,
    f.amt,
    n.nation_name,
    RANK() OVER (
        PARTITION BY
            f.pf_code
        ORDER BY
            f.amt DESC,
            f.nation_code
    ) AS ranking
    FROM foreigner f
    JOIN nationality n
    ON f.nation_code=n.nation_code
    JOIN prefecture p
    ON p.pf_code=f.pf_code
    WHERE f.nation_code <> "113"
) m
JOIN (
    SELECT
        f.pf_code,
        SUM(f.amt) as total
    FROM foreigner f
    WHERE f.nation_code <> "113"
    GROUP BY f.pf_code
) n
ON n.pf_code=m.pf_code
GROUP BY n.pf_code
ORDER BY total DESC, n.pf_code;
提出情報
提出日時2022/07/21 09:56:09
コンテスト第1回 SQLコンテスト
問題外国籍分布
受験者drillmachine
状態 (詳細)WA
(Wrong Answer: 誤答)
メモリ使用量89 MB
メッセージ
テストケース(通過数/総数)
0/2
状態
メモリ使用量
データパターン1
WA
84 MB
データパターン2
WA
89 MB