MySql数据库触发器使用教程


Posted in MySQL onJune 01, 2022

一、介绍

1、触发器是一种特殊的存储过程。触发器和存储过程一样,是一个能够完成特定功能、存储在数据库服务器上的SQL片段,但是触发器无语调用,当对数据库表中的数据执行DML操作时自动触发这个SQL片段的执行,无需手动调用。

2、在MySql中,只有执行insert,delete,update操作时才能触发触发器的执行

3、触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作

4、使用别名OLD和NEW来引用触发器中发生变化的记录内容,这与其他的数据库是相似的,现在触发器只支持行级触发,不支持语句级触发

二、操作

1、表数据准备

# 用户表
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for users
-- ----------------------------
DROP TABLE IF EXISTS `users`;
CREATE TABLE `users`  (
  `id` int(10) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `user_name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '用户名',
  `sex` varchar(1) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '性别',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

SET FOREIGN_KEY_CHECKS = 1;


# 用户操作日志表
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for user_log
-- ----------------------------
DROP TABLE IF EXISTS `user_log`;
CREATE TABLE `user_log`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `content` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,
  `create_time` datetime(0) DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

SET FOREIGN_KEY_CHECKS = 1;

2、触发器格式

# 创建只有一个执行语句的触发器

create trigger 触发器名 before|after 触发事件
on 表名 for each row
执行语句;

# 创建有多个执行语句的触发器

create trigger 触发器名 before|after 触发事件
on 表名 for each row
begin  
   执行语句列表
end;

3、操作

drop TRIGGER if EXISTS TRIGGER_test;
-- 需求1:当users表添加一行数据,则会自动在user_log添加日志记录
delimiter $$
CREATE TRIGGER TRIGGER_test after INSERT
on users FOR EACH ROW
BEGIN
INSERT INTO user_log(content,create_time) VALUES('添加了一条数据',NOW());
end $$
delimiter ;

INSERT INTO users(user_name,sex) VALUES('xiaohemaio','男');


-- 需求2:当users表修改一行数据,则会自动在user_log添加日志记录
drop TRIGGER if EXISTS TRIGGER_test1;

delimiter $$
CREATE TRIGGER TRIGGER_test1  BEFORE UPDATE
on users FOR EACH ROW
BEGIN
INSERT INTO user_log(content,create_time) VALUES('修改了一条数据',NOW());
end $$
delimiter ;

update users set user_name='迪丽热巴' WHERE id=3;

三、触发器NEW和OLD的使用

MySql中定义了NEW和OLD,用来表示触发器的所在表中,触发了触发器的那一行数据,来引用触发器中发生变化的记录内容。

MySql数据库触发器使用教程

使用方法:NEW.columnName (columnName为相应数据表某一列名)

1、案例

-- 案例一
drop TRIGGER if EXISTS TRIGGER_test2;

delimiter $$
CREATE TRIGGER TRIGGER_test2 after INSERT
on users FOR EACH ROW
BEGIN
INSERT INTO user_log(content,create_time) VALUES(CONCAT('添加的用户信息为:',NEW.user_name,' 性别为:',NEW.sex ),NOW());
end $$
delimiter ;

INSERT INTO users(user_name,sex) VALUES('xiaohemaio','男');


-- 案例二 
drop TRIGGER if EXISTS TRIGGER_test3;

delimiter $$
CREATE TRIGGER TRIGGER_test3  BEFORE UPDATE
on users FOR EACH ROW
BEGIN
INSERT INTO user_log(content,create_time) VALUES(CONCAT('将:',OLD.user_name,' 修改为:',NEW.user_name ),NOW());
end $$
delimiter ;

update users set user_name='迪丽热巴' WHERE id=4;

-- 案例三
drop TRIGGER if EXISTS TRIGGER_test4;

delimiter $$
CREATE TRIGGER TRIGGER_test4  BEFORE DELETE
on users FOR EACH ROW
BEGIN
INSERT INTO user_log(content,create_time) VALUES(CONCAT('将id为:',OLD.user_name,' 已删除' ),NOW());
end $$
delimiter ;

DELETE FROM  users WHERE id=4;

MySql数据库触发器使用教程

四、其他操作

-- 查看触发器
SHOW TRIGGERS;

-- 删除触发器
drop TRIGGER if EXISTS 触发器名;

五、注意事项

1、触发器中不能对本表进行insert,update,delete操作,以免递归循环触发

2、尽量少使用 触发器,假设触发器触发每次执行1s,insert table 500条数据,那么就需要触发500次触发器,光是触发器执行的时间就花费了500s,而insert 500条数据一共是1s,那么这个insert 的效率就非常低了。

3、触发器是针对每一行的数据,对增删改非常频繁的表上切记不要使用触发器,因为非常消耗资源。

补充:验证触发器

向用户表users插入数据。

mysql> INSERT INTO users (userName, password, name, nickName, sex, email, isManager) VALUE ('itbilu', 'e10adc3949ba59abbe56e057f20f883e', 'IT笔录', 'itbilu', 1, 'cn.liuht@gmail.com', 0);

users原来没有数据,刚插入的数据userId为1。向用户表角色表userRoles插入数据,使触发器触发:

mysql> INSERT INTO userRoles (userId, roleId) VALUE (1, 1);

刚才插入的数据已经使触发器触发,查看结果如下:

mysql> select isManager from users;
+-----------+
| isManager |
+-----------+
|         1 |
+-----------+

总结

到此这篇关于MySql数据库触发器使用的文章就介绍到这了,更多相关MySql触发器使用内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!


Tags in this post...

MySQL 相关文章推荐
MySQL的join buffer原理
Apr 29 MySQL
MySQL 百万级数据的4种查询优化方式
Jun 07 MySQL
MySQL 外键约束和表关系相关总结
Jun 20 MySQL
Unity连接MySQL并读取表格数据的实现代码
Jun 20 MySQL
MySQL中IF()、IFNULL()、NULLIF()、ISNULL()函数的使用详解
Jun 26 MySQL
MySQL深度分页(千万级数据量如何快速分页)
Jul 25 MySQL
为什么MySQL分页用limit会越来越慢
Jul 25 MySQL
SQL实现LeetCode(178.分数排行)
Aug 04 MySQL
MySQL高级进阶sql语句总结大全
Mar 16 MySQL
Mysql排查分析慢sql之explain实战案例
Apr 19 MySQL
分析MySQL优化 index merge 后引起的死锁
Apr 19 MySQL
MySQL的存储过程和相关函数
Apr 26 MySQL
MySQL选择合适的备份策略和备份工具
MySQL普通表如何转换成分区表
May 30 #MySQL
Mysql将字符串按照指定字符分割的正确方法
May 30 #MySQL
MySQL数据库安装方法与图形化管理工具介绍
MySQL数据库简介与基本操作
May 30 #MySQL
Mysql数据库事务的脏读幻读及不可重复读详解
May 30 #MySQL
mysql字段为NULL索引是否会失效实例详解
May 30 #MySQL
You might like
SWFUpload与CI不能正确上传识别文件MIME类型解决方法分享
2011/04/18 PHP
PHP实现的购物车类实例
2015/06/17 PHP
WordPress中登陆后关闭登陆页面及设置用户不可见栏目
2015/12/31 PHP
PHP静态成员变量和非静态成员变量详解
2017/02/14 PHP
非常有用的40款jQuery 插件推荐(系列二)
2011/12/25 Javascript
Javascript 检测键盘按键信息及键码值对应介绍
2013/01/03 Javascript
模拟多级复选框效果的jquery代码
2013/08/13 Javascript
jQuery学习笔记之总体架构
2014/06/03 Javascript
node.js中的http.response.setHeader方法使用说明
2014/12/14 Javascript
JS实现的新浪微博大厅文字内容滚动效果代码
2015/11/05 Javascript
详解JavaScript对象和数组
2015/12/03 Javascript
关于安卓手机微信浏览器中使用XMLHttpRequest 2上传图片显示字节数为0的解决办法
2016/05/17 Javascript
javascript判断firebug是否开启的方法
2016/11/23 Javascript
谈谈JavaScript中浏览器兼容问题的写法小议
2016/12/17 Javascript
Vue.js基础知识小结
2017/01/13 Javascript
Omi v1.0.2发布正式支持传递javascript表达式
2017/03/21 Javascript
js canvas实现写字动画效果
2018/11/30 Javascript
[01:02:46]VGJ.S vs NB 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
Python OpenCV获取视频的方法
2018/02/28 Python
如何真正的了解python装饰器
2020/08/14 Python
Python使用cn2an实现中文数字与阿拉伯数字的相互转换
2021/03/02 Python
CSS3字体效果的设置方法小结
2016/06/13 HTML / CSS
法国奢华女性时尚配饰网上商店:Monnier Frères
2016/08/27 全球购物
北美最大的手工艺品零售商之一:Michaels Stores
2019/02/27 全球购物
惠普香港官方商店:HP香港
2019/04/30 全球购物
如何用JQuery进行表单验证
2013/05/29 面试题
本科毕业生自我鉴定
2013/11/02 职场文书
名人演讲稿范文
2013/12/28 职场文书
小区门卫值班制度
2014/01/24 职场文书
管事部库房保管员岗位职责
2014/02/21 职场文书
清扬洗发水广告词
2014/03/14 职场文书
出纳2015年度工作总结范文
2015/10/14 职场文书
React + Threejs + Swiper 实现全景图效果的完整代码
2021/06/28 Javascript
Win10 和 Win11可以共存吗? win10/11产品生命周期/服务更新介绍
2021/11/21 数码科技
CPU不支持Windows11系统怎么办
2021/11/21 数码科技
MySQL脏读,幻读和不可重复读
2022/05/11 MySQL