openGauss数据库——高级数据管理-触发器

一、触发器及其触发函数

OpenGauss上的触发器创建和数据库系统概论有较大的区别——需要先创建一个函数(返回的是触发器,然后在函数里面写条件),然后再创建一个触发器(触发器调用的是触发函数)。

触发函数和触发器的功能不同,触发器是调用触发函数实现功能,因此触发函数的内容要写入触发的条件。触发器会在指定的数据库事件发生时自动执行函数。

一开始接触这种写法可能会感觉不适应,但其实这种写法减少了触发器内部的耦合,相当于将条件定义单独分离成一个函数,如果后期要修改条件,只需要重新编写触发函数,而不用更改整个触发器,更加便于后期的更改和维护。

二、语法格式及参数说明

触发函数语法格式

CREATE OR REPLACE FUNCTION function_name() RETURNS TRIGGER AS
$$
DECLARE
BEGIN

      函数体

END;
$$ LANGUAGE plpgsql;

触发函数内容说明

CREATE OR REPLACE FUNCTION:创建一个新的函数,如果同名函数已经存在,则用新的函数替换旧的函数。

function_name ------- 用户定义的函数,必须声明为不带参数并返回类型为触发器,在触发器触发时执行。

AS $$ :指定函数体的开始位置,并且使用 $ $ 符号作为标识符的分隔符。

BEGIN:函数体的开始位置。

END:函数体的开始位置。

$$ LANGUAGE plpgsql:指定使用plpgsql语言编写函数体,并且使用$符号作为标识符的分隔符。

触发器语法格式

(1) 创建触发器
CREATE TRIGGER trigger_name { BEFORE | AFTER | INSTEAD OF } { event [ OR … ] }
ON table_name
[ FOR [ EACH ] { ROW | STATEMENT } ]
[ WHEN ( condition ) ]
EXECUTE PROCEDURE function_name ( arguments );
(2) 修改触发器
ALTER TRIGGER trigger_name ON table_name RENAME TO new_trigger_name;
(3) 删除触发器
DROP TRIGGER trigger_name ON table_name [ CASCADE | RESTRICT ];

触发器参数说明

trigger_name ------- 触发器名称。
BEFORE ------- 触发器函数是在触发事件发生前执行。
AFTER ------- 触发器函数是在触发事件发生后执行。
INSTEAD OF ------- 触发器函数直接替代触发事件。
event ------- 启动触发器的事件,取值范围包括:INSERT、UPDATE、DELETE或TRUNCATE,也可以通过OR同时指定多个触发事件。
table_name ------- 触发器对应的表名称。
FOR EACH ROW | FOR EACH STATEMENT ------- 触发器的触发频率。
FOR EACH ROW ------- 是指该触发器是受触发事件影响的每一行触发一次。
FOR EACH STATEMENT ------- 是指该触发器是每个SQL语句只触发一次。
未指定时默认值为FOR EACH STATEMENT。约束触发器只能指定为FOR EACH ROW。
function_name ------- 用户定义的函数,必须声明为不带参数并返回类型为触发器,在触发器触发时执行。
arguments ------- 执行触发器时要提供给函数的可选的以逗号分隔的参数列表。
new_trigger_name ------- 修改后的新触发器名称。

三、演示案例

(1)创建源表及触发表

----创建源表及触发表
openGauss=# CREATE TABLE test_trigger_src_tbl(id1 INT, id2 INT, id3 INT);
openGauss=# CREATE TABLE test_trigger_des_tbl(id1 INT, id2 INT, id3 INT);

(2)创建触发器函数

----创建触发器函数
openGauss=# CREATE OR REPLACE FUNCTION tri_insert_func() RETURNS TRIGGER AS
           $$
           DECLARE
           BEGIN
                   INSERT INTO test_trigger_des_tbl VALUES(NEW.id1, NEW.id2, NEW.id3);
                   RETURN NEW;
           END
           $$ LANGUAGE PLPGSQL;

(3)创建INSERT触发器

----创建INSERT触发器
openGauss=# CREATE TRIGGER insert_trigger
           BEFORE INSERT ON test_trigger_src_tbl
           FOR EACH ROW
           EXECUTE PROCEDURE tri_insert_func();

(4)执行INSERT触发事件并检查触发结果

----执行INSERT触发事件并检查触发结果
openGauss=# INSERT INTO test_trigger_src_tbl VALUES(100,200,300);
openGauss=# SELECT * FROM test_trigger_src_tbl;
openGauss=# SELECT * FROM test_trigger_des_tbl;  //查看触发操作是否生效。

(5)删除触发器

----删除触发器
openGauss=# DROP TRIGGER insert_trigger ON test_trigger_src_tbl;
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值