首页 > 解决方案 > postgresql 上的更新类型

问题描述

这里是 Postgres 和 PL/pgSQL 的新手。

如何编写 PL/pgSQL 函数以根据对 postgres 数据库中的表/记录进行的更新类型(插入、删除等)执行不同的操作。

标签: sqlpostgresqlplpgsqlstored-functions

解决方案


你似乎在寻找一个触发器

在 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 文档以了解CREATE TRIGGER语句触发过程(最新版本提供了很多示例)。


推荐阅读