ソースコード
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位 人数",
    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 10:04:07
コンテスト第1回 SQLコンテスト
問題外国籍分布
受験者drillmachine
状態 (詳細)AC
(Accepted: 正答)
メモリ使用量91 MB
メッセージ
テストケース(通過数/総数)
2/2
状態
メモリ使用量
データパターン1
AC
91 MB
データパターン2
AC
79 MB