代码之家  ›  专栏  ›  技术社区  ›  vva

PostgreSQL的更新类型

  •  0
  • vva  · 技术社区  · 7 年前

    这里是Postgres和pl/pgsql的新手。

    如何编写一个pl/pgsql函数,根据对Postgres数据库中的表/记录所做的更新(插入、删除等)类型执行不同的操作?

    1 回复  |  直到 7 年前
        1
  •  3
  •   GMB    7 年前

    你好像在找 触发器 .

    在SQL中,触发器是在对象上发生特定事件时调用(激发)的过程,例如在更新、删除或插入表时。触发器可以响应许多用例,如实现业务完整性规则、清理数据、审计、安全性等。

    在Postgres中,应该首先定义一个pl/pgsql函数,然后在触发器声明中引用它。

    CREATE OR REPLACE FUNCTION my_table_function() RETURNS TRIGGER AS $my_table_trigger$
        BEGIN
            ...
        END
    $my_table_trigger$ LANGUAGE plpgsql;
    
    CREATE TRIGGER my_table_trigger
        AFTER INSERT OR UPDATE OR DELETE ON mytable
        FOR EACH ROW EXECUTE PROCEDURE my_table_function();
    

    从触发器代码中,您可以访问一组特殊变量,例如:

    • NEW , OLD :包含受查询影响的新/旧数据库记录的伪记录
    • TG_OP :触发触发器的操作( INSERT , UPDATE , DELETE ,…)

    使用这些变量和其他触发器机制,您可以分析或更改正在进行的操作,甚至可以通过引发异常来中止该操作。

    我建议阅读Postgres文档 the CREATE TRIGGER statement Trigger Procedure (最新的例子很多)。