赞
踩
大家好,今天给大家分享的知识是在pgsql新增数据之后的触发器
PostgreSQL 触发器(trigger)是一种特殊的函数,当某个数据变更事件(INSERT、UPDATE、
DELETE 或者 TRUNCATE 语句)或者数据库事件(DDL 语句)发生时自动执行,而不是由用
户或者应用程序进行调用。
首先我们要先创建一个函数,供触发器调用,在这我用新增数据后作为例子来演示,函数代码如下:
- 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替换为要新增数据的表
有了函数之后我们就可以写触发器了,代码如下:
- 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触发器的用法,如有想法,欢迎讨论~
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。