MySQL触发器

本文介绍了MySQL触发器,一种与表关联的特殊存储过程,可在数据修改时执行,提供安全性和复杂的数据完整性规则。触发器可用于审计、实现数据控制、同步数据以及执行计划任务。同时,文章详细阐述了创建、删除和查看触发器的方法,并给出了实际应用示例,如在文章表和文章类型表之间的联动更新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySql触发器的学习:

一、触发器简介:

1.触发器简介

① 触发器是和表关联的特殊的存储过程
② 可以在插入,删除或修改表中的数据时触发执行
③ 比数据库本身标准的功能有更精细和更复杂的数据控制能力

2.触发器的优点

①、安全性
可以基于数据库的值使用户具有操作数据库的某种权利。可以基于时间限制用户的操作,例如不允许下班后和节假日修改数据库数据;可以基于数据库中的数据限制用户的操作,例如不允许股票的价格的升幅一次超过10%。
②、审计
可以跟踪用户对数据库的操作。 审计用户操作数据库的语句;把用户对数据库的更新写入审计表。
③、实现复杂的数据完整性规则
实现非标准的数据完整性检查和约束。触发器可产生比规则更为复杂的限制。与规则不同,触发器可以引用列或数据库对象。例如,触发器可回退任何企图吃进超过自己保证金的期货。提供可变的缺省值。
④、实现复杂的非标准的数据库相关完整性规则。
触发器可以对数据库中相关的表进行连环更新。
在修改或删除时级联修改或删除其它表中的与之匹配的行。
在修改或删除时把其它表中的与之匹配的行设成NULL值。
在修改或删除时把其它表中的与之匹配的行级联设成缺省值。
触发器能够拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。
⑤、同步实时地复制表中的数据。
⑥、SQL触发器提供了运行计划任务的另一种方法。自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。例如,如果公司的帐号上的资金低于5万元则立即给财务人员发送警告数据。

3.触发器的限制

①、触发程序不能调用将数据返回客户端的存储程序,也不能使用采用CALL语句的动态SQL语句,但是允许存储程序通过参数将数据返回触发程序,也就是存储过程或者函数通过OUT或者INOUT类型的参数将数据返回触发器是可以的,但是不能调用直接返回数据的过程。
②、不能在触发器中使用以显示或隐式方式开始或结束事务的语句,如START TRANS-ACTION,COMMIT或ROLLBACK。

二、触发器的使用

1.创建触发器

CREATE TRIGGER trigger_name
trigger_time trigger_event ON tb_name
FOR EACH ROW trigger_stmt;

trigger_name:触发器的名称
trigger_time:触发时机 为AFTER|BEFORE
trigger_event:触发事件 为 DELETE|UPDATE|INSERT
tb_name:触发的表,即是在哪张表上建立触发器
trigger_stmt:触发器的程序体,可以是一条SQL语句或者是用BEGIN和END包含的多条语句
FOR EACH ROW:表示任何一条记录上的操作满足触发事件都会触发该触发器。

MySQL除了对INSERT、UPDATE、DELETE基本操作进行定义外,还定义了LOAD DATA和REPLACE语句,这两种语句也能引起上述6中类型的触发器的触发。

LOAD DATA 语句用于将一个文件装入到一个数据表中,相当与一系列的 INSERT操作。
REPLACE语句一般来说和INSERT语句很像,只是在表中有primary key或 unique索引时,如果插入的数据和原来primary key或unique索引一致时,会先删除原来的数据,然后增加一条新数据。

INSERT型触发器:插入某一行时激活触发器,通过 INSERT、LOAD DATA、REPLACE语句触发;
UPDATE型触发器:更改某一行时激活触发器,通过UPDATE语句触发;
DELETE型触发器:删除某一行时激活触发器,通过DELETE、REPLACE语句触发。

MySQL中定义了NEW和OLD,用来表示触发器的所在表中,触发了触发器的那一行数据。
① 在INSERT型触发器中,NEW用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
② 在UPDATE型触发器中,OLD用来表示将要或已经被修改的原数据,NEW用来表示将要或已经修改为的新数据;
③ 在DELETE型触发器中,OLD用来表示将要或已经被删除的原数据;
使用方法:NEW.columnName(columnName为相应数据表某一列名)
另外,OLD是只读的,而NEW则可以在触发器中使用SET赋值,不会再次触发触发器,造成循环调用。

2.删除触发器

DROP TRIGGER (IF EXISTS) [schema_name.]trigger_name

schema_name是数据库的名称,是可选的。如果省略了schema,将从当前数据库中舍弃触发程序。trigger_name是要删除的触发器的名称。

3.查看触发器

SHOW TRIGGERS;

三、触发器的应用

1.准备

① 文章表(article)、文章类型表(articletype)
② 表的字段、内容

文章表(article)

文章类型表(articletype)
在这里插入图片描述

2.例子

① 添加一条文章信息,文章类型articleTypeNum+1

CREATE TRIGGER insert_update_articleNum
AFTER INSERT ON article
FOR EACH ROW
BEGIN
UPDATE articletype SET articleTypeNum = articleTypeNum + 1 WHERE id = new.articleTypeId;
END

MySQL 数据库触发器创建 INSERT
在这里插入图片描述

insert into article (articleName,articleTypeId) values ('文章10',1);

运行该插入的sql语句article加一行,articleTypeNum + 1

② 删除一篇文章,articleType 里 articleTypeNum - 1

CREATE TRIGGER delete_update_articleNum
AFTER DELETE ON article
FOR EACH ROW
BEGIN 
UPDATE articletype SET articleTypeNum = articleTypeNum - 1 where id = new.articleTypeId;
END

MySQL 数据库触发器创建 DELETE
在这里插入图片描述

DELETE FROM article WHERE id = 1;

运行该删除sql语句article表里id 为1 的文章删除,articleType表里的articleTypeNum - 1;

③ 修改文章类型的id,文章类型表里原来的articleTypeNum - 1, 文章类型表里修改后的articleTypeNum +1

CREATE TRIGGER update_update_articleNum
AFTER UPDATE ON article
FOR EACH ROW
BEGIN
UPDATE articleType set articleNum = articleNum - 1 where articleTypeId = old.articleTypeId;
UPDATE articleType set articleNum = articleNum + 1 where articleTypeId = new.articleTypeId;
END

MySQL 数据库触发器创建 UPDATE
在这里插入图片描述

update article set articleTypeId = 1 where id = 2;

运行该修改sql后,article原来的文章类型的articleTypeNum - 1,article修改后的文章类型的articleTypeNum + 1;

https://blog.51cto.com/9291927/2095105

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值