ソースコード
WITH GOODS_CODE_avg as (
    select
        GOODS_CODE
        ,ROUND(avg(STD_COST_PRICE)) as avg_std_cost_price
    FROM
        SKU
    GROUP BY 1
)
,std_cost_price_set as (
    select
        GOODS_CODE
        ,SKU_CODE
        ,CASE
            WHEN SKU.STD_COST_PRICE < avg_std_cost_price THEN GOODS.STD_COST_PRICE
            ELSE SKU.STD_COST_PRICE
        END as STD_COST_PRICE_SET
        ,CASE
            WHEN SKU.STD_COST_PRICE < avg_std_cost_price THEN 'MODIFY'
            ELSE SKU.UPDATE_USER_NAME
        END as UPDATE_USER_NAME_SET
        ,CASE
            WHEN SKU.STD_COST_PRICE < avg_std_cost_price THEN '2024-08-31 00:00:00'
            ELSE SKU.USER_UPDATE_DATETIME
        END as USER_UPDATE_DATETIME_SET
    FROM
        SKU
        LEFT JOIN GOODS USING(GOODS_CODE)
        LEFT JOIN GOODS_CODE_avg USING(GOODS_CODE)
)
UPDATE
    SKU
SET
    STD_COST_PRICE = (
        SELECT
            STD_COST_PRICE_SET
        FROM
            std_cost_price_set
        WHERE
            SKU.GOODS_CODE = std_cost_price_set.GOODS_CODE
            AND SKU.SKU_CODE = std_cost_price_set.SKU_CODE
    )
    ,UPDATE_USER_NAME = (
        SELECT
            UPDATE_USER_NAME_SET
        FROM
            std_cost_price_set
        WHERE
            SKU.GOODS_CODE = std_cost_price_set.GOODS_CODE
            AND SKU.SKU_CODE = std_cost_price_set.SKU_CODE
    )
    ,USER_UPDATE_DATETIME = (
        SELECT
            USER_UPDATE_DATETIME_SET
        FROM
            std_cost_price_set
        WHERE
            SKU.GOODS_CODE = std_cost_price_set.GOODS_CODE
            AND SKU.SKU_CODE = std_cost_price_set.SKU_CODE
    )
;
提出情報
提出日時2024/12/06 17:41:27
コンテスト第2回 SQLコンテスト初級編
問題原価更新
受験者toru031794
状態 (詳細)AC
(Accepted: 正答)
メモリ使用量110 MB
メッセージ
テストケース(通過数/総数)
3/3
状態
メモリ使用量
データパターン1
AC
110 MB
データパターン2
AC
89 MB
データパターン3
AC
107 MB