-- シリーズテーブル更新
-- DROP FUNCTION f_series_update(kubun int4, mcode int4, scode int4, name "varchar", kana "varchar", recdv int4, usr "varchar", pc "varchar", count int4);


CREATE OR REPLACE FUNCTION f_series_update(
    kubun       int4,       -- 処理区分
    mcode       int4,       -- メーカーコード
    scode       int4,       -- シリーズコード
    name        "varchar",  -- シリーズ名
    kana        "varchar",  -- シリーズ名かな
    recdv       int4,       -- おすすめ区分
    usr         "varchar",  -- 更新ユーザ
    pc          "varchar",  -- æ›´æ–°PC
    count       int4)       -- 更新カウンタ

RETURNS int4 AS
$$
DECLARE
    cntcheck integer;
BEGIN
    --
    -- パラメータチェック
    --

    -- 処理区分
    IF kubun IS NULL OR kubun NOT IN (1,2,3) THEN
        RAISE EXCEPTION '処理区分が不正です';
    END IF;

    -- 必須チェック
    IF kubun IN (1,2) THEN
        IF recdv IS NULL THEN
            RAISE EXCEPTION '引数 recdv は必須です';
        END IF;
    END IF;
    IF kubun IN (2,3) THEN
        IF mcode IS NULL THEN
            RAISE EXCEPTION '引数 mcode は必須です';
        END IF;
        IF scode IS NULL THEN
            RAISE EXCEPTION '引数 scode は必須です';
        END IF;
        IF count IS NULL THEN
            RAISE EXCEPTION '引数 count は必須です';
        END IF;
    END IF;

    -- 桁数チェック
    IF kubun IN (1,2) THEN
        IF s_check_length(name, 256) = FALSE THEN
            RAISE EXCEPTION '引数 name が不正です';
        END IF;
        IF s_check_length(kana, 256) = FALSE THEN
            RAISE EXCEPTION '引数 kana が不正です';
        END IF;
    END IF;
    IF kubun IN (1,2,3) THEN
        IF s_check_upd(usr, pc) = FALSE THEN
            RAISE EXCEPTION '引数 usr&pc が不正です';
        END IF;
    END IF;

    -- 存在チェック
    IF kubun IN (1,2) THEN
        SELECT makercd INTO cntcheck FROM t_maker WHERE makercd = mcode AND delflg = FALSE;
          IF NOT FOUND THEN
            RAISE EXCEPTION '引数 mcode が存在しません';
        END IF;
    END IF;

    -- 品目基本属性チェック
    IF kubun IN (3) THEN
        SELECT itemcd INTO cntcheck FROM t_item_basic_attr WHERE makercd = mcode AND seriescd = scode AND delflg = false;
        IF FOUND THEN
            RETURN -10;
        END IF;
    END IF;

    -- 更新カウンタチェック
    IF kubun IN (2,3) THEN
        SELECT updcnt INTO cntcheck FROM t_series WHERE makercd = mcode AND seriescd = scode;
          IF NOT FOUND OR cntcheck <> count THEN
            RETURN -11;
        END IF;
    END IF;

    --
    -- 更新処理
    --

    -- 追加
    IF kubun = 1 THEN
        INSERT INTO t_series(makercd, seriesnm, seriesnmkana, recommenddiv, updusrnm, updpcnm)
               VALUES(mcode, name, kana, recdv, usr, pc);

    -- æ›´æ–°
    ELSIF kubun = 2 THEN
        UPDATE t_series
           SET seriesnm     = name,
               seriesnmkana = kana,
               recommenddiv = recdv,
               updusrnm     = usr,
               updpcnm      = pc
         WHERE makercd = mcode AND seriescd = scode;

    -- 削除
    ELSIF kubun = 3 THEN
        UPDATE t_series
           SET delflg = TRUE,
               updusrnm = usr,
               updpcnm = pc
         WHERE makercd = mcode AND seriescd = scode;
    END IF;

    RETURN 1;
END;
$$
LANGUAGE 'plpgsql' VOLATILE;