当前位置:首页 > 问答百科 > 正文内容

数据库触发器是什么(SQL语言基础:触发器相关知识介绍)

福瑞号2022-12-01 19:15:09问答百科202
数据库触发器是什么(SQL语言基础:触发器相关知识介绍)-图1
1、触发器 Trigger介绍
触发器可以实现完整性规则和保证一些复杂业务规则的实施。针对示警或满足特定 条件下自动执行某项任务来说,触发器时十分有用的机制。触发器是由事件1驱动的特殊过程,一旦由某个用户定义,任何用户对该触发器指定的数据新增、删除、修改操作,系统会自动激活相应的触发器,在核心层进行集中的完整性控制。
2、触发器特点
1) 当数据库开发者声明事件发生时,触发器激活,事件可以时对某个特定关系的插入、删除、更新。
2) 触发器被事件激活后,不是立即执行,而是先由触发器测试触发条件,若条件不成立,响应该事件的触发器将不做任何处理。
3) 如果触发器的申明条件满足时,则与该触发器相连的动作由DBMS执行。可以阻止事件、撤销事件。
注意事项:
1)触发器为数据库对象时,创建触发器必须指定名称、在其定义触发器的表、触发器触发时机、触发器做什么事情。触发器不能作用在临时表,但可以引用临时表。
3、触发器分类
行级触发器:对事件影响的每一行(FOR EACH ROW) ,每一元组执行。
语句级触发器:对整个事件只执行一次触发过程(FOR EACH STATEMENT)。是触发器默认方式。
4、创建触发器
触发器定义包括:触发器的触发事件、触发器执行的动作。针对update操作中还可以指定特定的属性或属性组的修改为触发条件。事件的触发还有两个相关时间:before、after。
before:触发器是在事件发生之前触发。
after:触发器是在事件发生之后触发。
创建触发器语法格式:
create trigger <触发器名称>[{after|before}]
{[delete|update|updateof[列名清单]]}
on 表名
[referencing <临时视图名称>]
[when<触发条件>]
begin
<触发动作>
end [触发器]
参数说明:
before:说明DBMS在执行触发语句之前激发触发器。
after:说明DBMS在执行触发语句之后激发触发器。
delete:delete触发器,每当一个delete语句从表中删除一行时激发触发器。
insert:insert,每当一个insert语句从表中插入一行时激发触发器。
update:update触发器,每当update语句修改由of子句指定的列值时激发触发器。如果忽略of子句,表示任何列值时,DBMS都将激发触发器。
referencing <临时视图名称>:指定临时视图的别名。在触发器运行过程中,系统会生成两个临时视图,分别存放更新值(旧值)、更新后的值(新值)。
行级触发器:默认临时视图名分别时OLD、NEW。
语句触发器:默认临时视图名分别时OLD-TABLE、NEW-TABLE。触发器结束临时视图也会随着销毁。
WHEN<触发条件>:指定触发器的触发条件。只有条件满足触发条件时,才会激发触发器。触发条件必须包含临时视图名、不包含查询。
针对示警或满足特定条件下自动执行某项任务来说,触发时非常有用的机制。
5、更改触发器
语法格式:
alter trigger <触发器名> [{after|before}]
要执行的SQL语句
end
6、删除触发器
drop trigger <触发器名>[,...n]
说明:n表示可以指定多个触发器的占位符。
7、完整示例
- 需求: 当向员工表插入一条记录时,希望mysql自动同时往日志表插入数据
-- 创建触发器(添加)
CREATE TRIGGER tri_empAdd AFTER INSERT ON employee FOR EACH ROW -- 当往员工表插入一条记录时
INSERT INTO test_log(content) VALUES('员工表插入了一条记录');
CREATE TRIGGER tri_empUpd AFTER UPDATE ON employee FOR EACH ROW -- 当往员工表修改一条记录时
INSERT INTO test_log(content) VALUES('员工表修改了一条记录');
CREATE TRIGGER tri_empDel AFTER DELETE ON employee FOR EACH ROW -- 当往员工表删除一条记录时
INSERT INTO test_log(content) VALUES('员工表删除了一条记录');
-- 删除创建触发器
DROP TRIGGER tri_empAdd;
触发器事件:数据库表行的插入、删除、修改。也就是执行insert、delete、update语句。
想了解更多精彩内容,快来关注数据库技术笔记

扫描二维码推送至手机访问。

版权声明:本文由福瑞号发布,如需转载请注明出处。

本文链接:http://furui.com.cn/7594.html

“数据库触发器是什么(SQL语言基础:触发器相关知识介绍)” 的相关文章

名不正言不顺是哪家思想(名不正言不顺是哪家的思想)

名不正言不顺是哪家思想(名不正言不顺是哪家的思想)

“名不正,言不顺”是儒家的思想。“名不正,言不顺”出自《论语·子路》,原句为:名不正则言不顺,言不顺则事不成。这句话的意思是:名义不正当的话,道理就没法讲通;道理讲不通,事情就办不成。 名实论的介绍 名实论是中国古代哲学的范畴之一,自先秦开始,诸子百家就开始了名实之辩。名实论之“名”指的是名称、形...

什么叫移情别恋(弗洛伊德很现实的名言)

什么叫移情别恋(弗洛伊德很现实的名言)

人的一生,总会遇到一些移情的人,何为移情呢?就是喜欢改变自己的情趣,转移自己的情感。人的一生,也总会遇到一些移情别恋的人,何为移情别恋呢?就是喜欢把对某人的态度或情绪转移到另一个人身上,或把自己的主观情感移到客观对象上,说白了就是爱上了别人。 不光是自己能遇到,有时候自己何尝又不是这种人?人的这一生...

什么是赤道(赤道在地球人眼中是什么什么样的)

什么是赤道(赤道在地球人眼中是什么什么样的)

赤道是地球面上某一点,在随着地球自转的轨迹中,画的最长的那条线,叫赤道。长度达到了四十多万千米,同时还是纬线的基准线,就是说赤道的纬度是零度,同时它还是地球上最长的纬线。 赤道途径许多国家,其中比较大的有印度尼西亚、厄瓜多尔、哥伦比亚、巴西、刚果、苏马里、马尔代夫等等。其中比较有意思的是厄瓜多尔,...

松鼠是属于哪一类的动物(小松鼠:大自然的扩建者)

松鼠是属于哪一类的动物(小松鼠:大自然的扩建者)

夏天的清晨,当我们漫步在树林里,总会见到一种灵动的生物在林间跳跃,从这棵树的枝头跳到另一棵树的枝头,一根巨大毛茸茸的尾巴在不停摆动,有时会停在树干上好奇地看着你,圆溜溜的大眼睛特别有神,进食时那鼓鼓的腮班子一动一动地特别搞笑,看到这里,相信很多人都这知道了,这就是可爱的小松鼠。 松鼠是一种常年生活...

一个口里面一个女是什么字(口里—个女子是啥字)

一个口里面一个女是什么字(口里—个女子是啥字)

一个口里面一个女是因【nan】字。因的意思从造字词义上看,女外有围,意为闺,女入闺中,可意会为闺中少女,未闻世的小女孩,这也是古语因因称呼小女孩。 囡的组词:因因[ nan nan ]对小孩儿的亲热称呼。小因[xiaonan]方言。泛指小孩子。洋因因[yang nan nan]方言。即洋娃娃。年度因...

秋翠的寓意(好听的女孩名字大全)

秋翠的寓意(好听的女孩名字大全)

1、琼瑶 出自于“投我以木桃,报之以琼瑶”。琼瑶:美玉。用来形容女子纯洁无暇。 2、梦远:出自宋李煜:“闲梦远,南国正清秋。” 3、舒欣:舒心、舒服的意思。希望宝宝生活能够舒心舒服、平安健康。欣字欣赏和欢欣的含义,一来是希望宝宝将来能够有欣赏他人的习性,另一个方面则是希望宝宝将来开心快乐的过好每一天...