postgres触发器

一个触发器声明了当执行一种特定类型的操作时数据库应该自动执行一个特殊的函数。触发器可以被附加到表、视图和外部表。触发器经常用于做完整性约束,或者某种业务规则的约束。

1. 触发器的创建语法如下:

 

CREATE [CONSTRAINT] TRIGGER name 
{ BEFORE | AFTER | INSTEAD OF } { event [ OR ...] } 
ON table_name
[ FROM referenced_table_name ]
{[ NOT DEFERRABLE ][ DEFERRABLE ]{[ INITIALLY IMMEDIATE ][ INITIALLY DEFERRED]}} 
[ FOR [ EACH ] { ROW | STATEMENT } ]
[ WHEN (condition) ]
EXECUTE PROCEDURE function_name ( arguments )

 

2. 触发器的创建步骤如下:

 

先为触发器创建一个执行函数,返回类型为触发器类型,然后创建相应的触发器。

3. 触发器的分类如下:

(1)语句级触发器:一条SQL语句,触发器只执行一次,即使是修改了零行数据的SQL,也会导致相应的触发器执行。

(2)行级触发器:每行发生变化,就会执行一次触发器。

(3)BEFORE触发器:在触发事件之前执行触发器。

(4)AFTER触发器:在触发事件之后执行触发器。

4. 触发器中的一些特殊变量如下:

(1)NEW

数据类型是RECORD;该变量为行级触发器中的INSERT/UPDATE操作保持新数据行。在语句级别的触发器以及DELETE操作,这个变量未被赋值。

(2)OLD

数据类型是RECORD;该变量为行级触发器中的UPDATE/DELETE操作保持新数据行。在语句级别的触发器以及INSERT操作,这个变量未被赋值。

(3)TG_NAME

数据类型是name;该变量包含实际触发的触发器名。

(4)TG_WHEN

数据类型是text;是值为BEFORE、AFTER或INSTEAD OF的一个字符串,取决于触发器的定义。

(5)TG_LEVEL

数据类型是text;是值为ROW或STATEMENT的一个字符串,取决于触发器的定义。

(6)TG_OP

数据类型是text;是值为INSERT、UPDATE、DELETE或TRUNCATE的一个字符串,它说明触发器是为哪个操作引发。

(7)TG_RELID

数据类型是oid;是导致触发器调用的表的对象 ID。

(8)TG_RELNAME

数据类型是name;是导致触发器调用的表的名称。现在已经被废弃,并且可能在未来的一个发行中消失。使用TG_TABLE_NAME替代。

(9)TG_TABLE_NAME

数据类型是name;是导致触发器调用的表的名称。

(10)TG_TABLE_SCHEMA

数据类型是name;是导致触发器调用的表所在的模式名。

(11)TG_NARGS

数据类型是integer;在CREATE TRIGGER语句中给触发器过程的参数数量。

(12)TG_ARGV[]

数据类型是text数组;来自CREATE TRIGGER语句的参数。索引从 0 开始记数。非法索引(小于 0 或者大于等于tg_nargs)会导致返回一个空值。

点击打开链接原文地址

http://blog.csdn.net/iihero/article/details/8218753

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值