• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL 触发器的使用及需要注意的地方

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论

关于触发器

现实开发中我们经常会遇到这种情况,比如添加、删除和修改信息的时候需要记录日志,我们就要在完成常规的数据库逻辑操作之后再去写入日志表,这样变成了两步操作,更复杂了。

又比如删除一个人员信息的时候,需要将他的购物记录、收货地址、收藏夹等都删了,这个连续的操作容易出错,一致性和完整性不好保证。这时候就要使用触发器,既可以免去一堆的业务逻辑代码,又能更好的保证数据完整性。

触发器(trigger)是一种与表有关的数据库对象:在满足定义条件时触发某种操作,并执行触发器中定义的语句集合。触发器的这种特性可以协助应用在数据库端保证数据的完整性。

它是一种与表事件相关的特殊的存储过程,当对一个表进行操作( insert,delete, update)时就会激活执行。

触发器的使用

创建触发器

创建触发器的语法如下:

CREATE TRIGGER trigger_name trigger_time trigger_event ON t_name FOR EACH ROW trigger_stmt

说明:

trigger_name:触发器名称

tirgger_time:触发执行时间点,数据操作前(BEFORE) 或者 数据操作后(AFTER)

trigger_event:触发事件,增(INSERT)、删(DELETE)、改(UPDATE)

t_name:指的是在 t_name 这张表上建立触发器

trigger_stmt:触发器的程序体,可以是一条SQL语句或者是用BEGIN和END包含的多条语句

触发器只能创建在永久表(Permanent)上,不能创建在临时表(Temporary)上

FOR EACH ROW 固定表达式,表示任何一条记录上的操作满足触发事件都会触发该触发器

tirgger_time有两种类型,trigger_event有三种类型,所以他们一共有6种组合:BEFORE INSERT,BEFORE DELETE,BEFORE UPDATE,AFTER INSERT,AFTER DELETE,AFTER UPDATE

示例(先创建一个日志表,用于触发器触发时候填入值):

/*先创建一个日志表,用于触发器触发时候填入值*/
mysql> DROP TABLE IF EXISTS `TriggerLog`;
Query OK, 0 rows affected

mysql> CREATE TABLE `TriggerLog`
(
  `id` INT auto_increment PRIMARY KEY,
  `trigger_time` VARCHAR(30),
  `trigger_event` VARCHAR(30),
  `memo` VARCHAR(200)
);
Query OK, 0 rows affected

Insert类型触发器:

mysql>
/*这边声明SQL脚本的结束符为// */
DELIMITER //
DROP TRIGGER IF EXISTS trig_after_insert;
CREATE TRIGGER trig_after_insert AFTER INSERT ON students FOR EACH ROW
BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','insert',concat('new student info,id:',cast(new.studentid as char)));
END //
Query OK, 0 rows affected

mysql>
/*重置SQL脚本的结束符为; */
DELIMITER ;
Query OK, 0 rows affected

mysql>
/*插入一条数据 */
insert into students(studentname,score,classid) values('trigger1',100,0);
Query OK, 1 row affected


mysql&gt<a>本文来源gao($daima.com搞@代@#码8网^</a>;
/*查询日志表看是否有触发写入 */
select * from `TriggerLog`;
+----+--------------+---------------+------------------------+
| id | trigger_time | trigger_event | memo          |
+----+--------------+---------------+------------------------+
| 1 | after    | insert    | new student info,id:21 |
+----+--------------+---------------+------------------------+
1 row in set

Update类型触发器:

mysql>
/*这边声明SQL脚本的结束符为// */
DELIMITER //
DROP TRIGGER IF EXISTS trig_after_update;
CREATE TRIGGER trig_after_update AFTER UPDATE ON students FOR EACH ROW
BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','update',concat('update student info,id:',cast(new.studentid as char)));
END //
Query OK, 0 rows affected

mysql>
/*重置SQL脚本的结束符为; */
DELIMITER ;
Query OK, 0 rows affected

mysql>
/*更新数据 */
update students set score=99 where studentname='trigger1';
Query OK, 1 row affected
Rows matched: 1 Changed: 1 Warnings: 0

mysql>
/*查询日志表看是否更新的时候有触发写入 */
select * from `TriggerLog`;
+----+--------------+---------------+---------------------------+
| id | trigger_time | trigger_event | memo           |
+----+--------------+---------------+---------------------------+
| 1 | after    | insert    | new student info,id:21  |
| 2 | after    | update    | update student info,id:21 |
+----+--------------+---------------+---------------------------+
2 rows in set

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL 触发器的使用及需要注意的地方

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址