pgsql触发器

大家好,今天给大家分享的知识是在pgsql新增数据之后的触发器

文章目录


一、触发器是什么?

PostgreSQL 触发器(trigger)是一种特殊的函数,当某个数据变更事件(INSERT、UPDATE、

DELETE 或者 TRUNCATE 语句)或者数据库事件(DDL 语句)发生时自动执行,而不是由用

户或者应用程序进行调用。

二、使用步骤

1.创建函数

首先我们要先创建一个函数,供触发器调用,在这我用新增数据后作为例子来演示,函数代码如下:

sql 复制代码
CREATE OR REPLACE FUNCTION insert_test_table()
RETURNS TRIGGER
LANGUAGE plpgsql
AS $function$
BEGIN
    IF NEW.id = '666' THEN
    INSERT INTO(id,name) test_table VALUES(NEW.id,'姓名');
    END IF;

    RETURN NEW;
END;
$function$;

此处的insert_test_table为函数名,test_table替换为要新增数据的表

2.创建触发器

有了函数之后我们就可以写触发器了,代码如下:

sql 复制代码
CREATE TRIGGER insert_test_table_trigger
AFTER INSERT ON test_table_before
FOR EACH ROW
EXECUTE FUNCTION insert_test_table();

此处的insert_test_table_trigger为触发器的名称,AFTER INSERT的意思是在新增之后调用触发器,也可以改为BEFORE,新增之前调用来触发器,当然insert操作也可以替换为delete或者update操作,test_table_before就是在对此表进行新增操作之后再对test_table表再进行新增数据操作,最后一句就是调用我们上面所写的函数。


总结

以上就是pgsql触发器的用法,如有想法,欢迎讨论~

相关推荐
宠..8 小时前
创建单选按钮控件
java·服务器·数据库
李慕婉学姐8 小时前
Springboot社会工作机构管理系统w19724cv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
杰克尼8 小时前
mysql_day2总结
数据库·mysql
九河云9 小时前
华为云 DRS 数据复制服务:数据库无缝迁移上云的零停机实践
大数据·数据库·华为云
姓蔡小朋友9 小时前
MySQL多表查询
数据库·mysql
云飞云共享云桌面9 小时前
SolidWorks服务器怎么实现研发软件多人共享、数据安全管理
java·linux·运维·服务器·数据库·自动化
Elastic 中国社区官方博客9 小时前
Elasticsearch:使用 ES|QL 与 dense_vector 字段
大数据·数据库·人工智能·sql·elasticsearch·搜索引擎·全文检索
Channing Lewis9 小时前
mysql.connector.errors.OperationalError: 1040 (08004): Too many connections
数据库·mysql·adb
数据知道9 小时前
一文掌握向量数据库Chroma的详细使用
数据库·python·向量数据库
虹科网络安全9 小时前
艾体宝洞察 | Redis vs Valkey:解决 ElastiCache 的无序扩张与资源效率问题
数据库·redis·spring