MySQL 触发器的使用和理解
网络编程 2021-07-05 14:37www.168986.cn编程入门
这篇文章主要介绍了MySQL 触发器的使用和理解,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
1.触发器是什么?
一类特殊的数据库程序,可以监视某种数据的操作(insert/update/delete),并触发相关的操作(insert/update/delete),保护数据的完整性。
个人理解就有点类似于Java的观察者模式,一个对象变化,观察者也跟着做出响应。
Mysql好像是从5.0以后开始支持触发器的。
2.创建触发器
创建触发器我将介绍两种方式用语句创建,用navicat创建。
创建触发器的语法如下
CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name FOR EACH ROW trigger_stmt trigger_name触发器的名称 tirgger_time触发时机,为BEFORE或者AFTER trigger_event触发事件,为INSERT、DELETE或者UPDATE tb_name表示建立触发器的表明,就是在哪张表上建立触发器 trigger_stmt触发器的程序体,可以是一条SQL语句或者是用BEGIN和END包含的多条语句 所以可以说MySQL创建以下六种触发器 BEFORE INSERT,BEFORE DELETE,BEFORE UPDATE AFTER INSERT,AFTER DELETE,AFTER UPDATE
其中,触发器名参数指要创建的触发器的名字
BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后
FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器
创建多个执行语句的触发器
CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW BEGIN 执行语句列表 END
NEW和OLD的使用:
触发器类型 | new和old的使用 |
insert | new代表新增的数据 |
update | new代表更新后的数据,old代表更新前的数据 |
delete | old代表要删除的数据 |
某一个字段可以用new/lod.字段名
接下来我们创建2个表用来测试
stu表主表(被观察者)
DROP TABLE IF EXISTS `stu`; CREATE TABLE `stu` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'id', `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '姓名', `age` int(11) NULL DEFAULT NULL COMMENT '年龄', `sort` int(11) NULL DEFAULT NULL COMMENT '排序字段', PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 18 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;
stu_log表触发器关联表(观察者)
DROP TABLE IF EXISTS `stu_log`; CREATE TABLE `stu_log` ( `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT, `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL, `create_time` datetime(0) NULL DEFAULT NULL, PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 7 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;
现在我们假设有这样一个业务,在stu表新增和删除数据时,同步在stu_log中记录日志,记录name和时间。
如果不使用触发器,我们就需要编写代码来实现这个需求,触发器可以帮我们轻松的实现。
我们使用语句来创建一个insert触发器
DROP TRIGGER IF EXISTS `insert_log`; delimiter ;; CREATE TRIGGER `add_log` AFTER INSERT ON `stu` FOR EACH ROW BEGIN INSERT INTO stu_log(name,create_time) VALUES(new.`name`,now()); END ;; delimiter ;
执行结果
然后我们再用navicat创建一个delete触发器
step1右键stu表,选择设计表----触发器
step2:如图所示填选,选择删除前触发
step3在下方定义框内写执行语句,如图 记得点保存!
语句
begin INSERT INTO stu_log(name,create_time) VALUES(old.`name`,now()); end
3.使用触发器
测试一下新增一条数据
insert into stu (name,age) VALUES('李白',36)
查看stu表和stu_log表
如图,触发器已经生效了!
测试删除一条数据
DELETE from stu where name = '李白'
查看stu表和stu_log表
如图,触发器已经生效了!
以上就是MySQL 触发器的使用和理解的详细内容,更多关于MySQL 触发器的资料请关注狼蚁SEO其它相关文章!
上一篇:MySQL线上死锁分析实战
下一篇:MySQL 字段默认值该如何设置
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程