网站首页 > 技术文章 正文
【本文详细介绍了数据库中触发器的基本概念和使用方法,欢迎读者朋友们阅读、转发和收藏!】
1 基本概念
1.1 触发器的概述
触发器其实是一种特殊的存储过程。一般的存储过程是通过存储过程名直接调用,而触发器主要是通过事件 ( 增、删、改 ) 进行触发而被执行的,在表中数据发生变化时自动强制执行。
常见的触发器有两种: after(for) 、 instead of, 用于 insert 、 update 、 delete 事件。
after(for) 表示执行代码后,执行触发器
instead of 表示执行代码前,用已经写好的触发器代替你的操作。
1.2 触发器的用法
创建触发器
语法如下
CREATE TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。
触发程序与命名为 tbl_name 的表相关。 tbl_name 必须引用永久性表。不能将触发程序与临时表或视图关联起来。
trigger_time 是触发程序的动作时间。它可以是 BEFORE 或 AFTER ,以指明触发程序是在激活它的语句之前或之后触发。
trigger_event 指明了激活触发程序的语句的类型。 trigger_event 可以是下述值之一:
? INSERT :将新行插入表时激活触发程序,例如,通过 INSERT 、 LOAD DATA 和 REPLACE 语句。
? UPDATE :更改某一行时激活触发程序,例如,通过 UPDATE 语句。
? DELETE :从表中删除某一行时激活触发程序,例如,通过 DELETE 和 REPLACE 语句。
请注意, trigger_event 与以表操作方式激活触发程序的 SQL 语句并不很类似,这点很重要。
例如,关于 INSERT 的 BEFORE 触发程序不仅能被 INSERT 语句激活,也能被 LOAD DATA 语句激活。
可能会造成混淆的例子之一是 INSERT INTO .. ON DUPLICATE UPDATE ... 语法: BEFORE INSERT 触发程序对于每一行将激活,后跟 AFTER INSERT 触发程序,或 BEFORE UPDATE 和 AFTER UPDATE 触发程序,具体情况取决于行上是否有重复键。
对于具有相同触发程序动作时间和事件的给定表,不能有两个触发程序。
例如,对于某一表,不能有两个 BEFORE UPDATE 触发程序。
但可以有 1 个 BEFORE UPDATE 触发程序和 1 个 BEFORE INSERT 触发程序,或 1 个 BEFORE UPDATE 触发程序和 1 个 AFTER UPDATE 触发程序。
trigger_stmt 是当触发程序激活时执行的语句。
如果你打算执行多个语句,可使用 BEGIN ... END 复合语句结构。这样,就能使用存储子程序中允许的相同语句。
删除触发器
使用 DROP TRIGGER 语句可以删除 MYSQL 中已经定义的触发器。
猜你喜欢
- 2024-09-23 (二)SQL数据模式、表、索引的建立与删除
- 2024-09-23 当我们输入一条SQL查询语句时,发生了什么?
- 2024-09-23 超详细!SQL语法速成就靠这篇了!(下)
- 2024-09-23 sql语句(sql语句增删改查)
- 2024-09-23 数据库触发器(数据库触发器的创建和使用)
- 2024-09-23 SQL创建触发器(sql创建触发器禁止修改成绩)
- 2024-09-23 MySQL_08_触发器(mysql触发器的使用及语法)
- 2024-09-23 被低估的SQL(被低估的中国半导体龙头)
- 2024-09-23 都2021年了不会还有人不会用SQL吧
- 2024-09-23 Navicat工具中“清空表”与“截断表”区别,望文生义惹的祸
- 1514℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 573℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 513℃MySQL service启动脚本浅析(r12笔记第59天)
- 486℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 486℃启用MySQL查询缓存(mysql8.0查询缓存)
- 469℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 449℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 447℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (83)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)