sql - postgresql 上的更新类型
问题描述
这里是 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
: 触发触发器的操作 (INSERT
,UPDATE
,DELETE
, ...)
使用这些变量和其他触发机制,您可以分析或更改正在进行的操作,甚至通过引发异常来中止它。
我建议阅读 Postgres 文档以了解CREATE TRIGGER
语句和触发过程(最新版本提供了很多示例)。
推荐阅读
- c# - 有没有办法在 Unity 中部分地为精灵设置动画
- node.js - Google Cloud Platform SQL 实例不接受使用自定义用户凭据的 **nodejs 应用程序** 连接
- c# - 在 asp.net 核心中,为什么 await context.ChallengeAsync() 没有按预期工作?
- loops - CSV 迭代/循环
- amazon-web-services - 无服务器 DynamoDB 未显示在 AWS 管理控制台中
- amazon-s3 - 下载和转换 Parquet 文件
- python - 无法使用请求模块在python中代理请求
- php - 如何阅读此日期时间格式 2019-12-17T17:23:49.782Z?
- python-3.x - 确保统一功能签名的最佳方法
- c++ - 如何从 wav 文件中获取采样率?