sql - postgresql 的更新类型

标签 sql postgresql plpgsql stored-functions

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

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

最佳答案

您似乎在寻找触发器

在 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 :触发触发器的操作(INSERTUPDATEDELETE、...)

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

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

关于sql - postgresql 的更新类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54451753/

相关文章:

mysql - 如何获取其他表上的元素计数并按其排序

postgresql - 无法在 DDL 中使用声明的变量

performance - 具有许多子选择的 INSERT - 性能和错误选择性

sql - 触发错误时回滚事务

sql - postgres 错误 "collation "default.pg_catalog“编码 "UTF8"不存在”

mysql - 在 Open Query SQL 语句中指定表

MySQL - 如何按名称排序,然后按字母数字有选择地对表进行排序?

MySQL 比较开始和结束时间

sql - Azure SQL MI - 使用专用终结点的优点

ruby-on-rails - 使用 Postgresql 在 OS X Lion 上安装 Sphinx