sql >> データベース >  >> RDS >> PostgreSQL

pgsqlでトリガー関数を動的に作成するにはどうすればよいですか?

    2つの$$セクションが混乱していました。代わりに$name$構文を使用することで、これらを分離できます。

    また、トリガーにRETURNがありませんでした。

    CREATE OR REPLACE FUNCTION trigen(tbl text) RETURNS void AS $T1$
    BEGIN
        EXECUTE format(
        'CREATE FUNCTION %s_insertCnt() RETURNS TRIGGER AS $T2$
        BEGIN
            UPDATE insertions SET n = n + 1 WHERE tablename = %s;
            RETURN NEW;
        END
        $T2$ LANGUAGE plpgsql', tbl, quote_nullable(tbl));
    
        EXECUTE format('CREATE TRIGGER %s_inCnt BEFORE INSERT ON %s
        FOR EACH ROW EXECUTE PROCEDURE %s_insertCnt();', tbl, tbl, tbl);
        END
    $T1$ LANGUAGE plpgsql;
    



    1. SQLデータベースにアラビア文字を挿入する方法は?

    2. 行を分離するための更新にselect...を使用する最小限の例

    3. Laravelが参加し、複数のテーブルから選択します

    4. MAXまたはOrderByLimit1を選択します