当前位置: 首页 > news >正文

mysql触发器的简单使用

mysql触发器

触发器是一个特殊的存储过程,在事件delete、insert、update发生时自动执行一条或多条SQL语句(执行多条SQL语句需要用begin、end 包裹起来)

创建触发器

创建触发器的四大必要条件

  • 唯一的触发器名称
  • 触发器关联的表
  • 触发器响应的事件(delete、insert、update)
  • 触发器执行时机(before、after)

创建触发器语句示例

CREATE TRIGGER 触发器名称
BEFORE|AFTER 事件 
ON 关联的数据表
FOR EACH ROW 
--单条SQL语句
INSERT xxxxx on xxx;
--多条语句用begin、end包裹
--BEGIN 
--	INSERT xxxxx on xxx;
--	UPDATE xxx where xxx;
--END
查看触发器
show triggers;
删除触发器
DROP trigger if exists 触发器名;

注意:只有数据表才支持触发器,视图和临时表都不支持,每个表最多支持6个触发器(每条insert、update、delete的before和after),单一触发器不能与多个事件和多个表关联

触发器使用
insert触发器

insert触发器在insert语句执行之前(before)或者执行之后(after)执行,在insert触发器代码内,可以引用一个名为"NEW" 的虚拟表,访问被插入的行。

在before insert 触发器中,NEW 中的值可以被更新

对于QUTO_INCREMENT 的列,NEW 在 insert执行之前包含0,执行之后包含新的自动生成值

示例

--在插入记录后返回新增的id
CREATE TRIGGER mytrigger
AFTER insert 
ON mytable
FOR EACH ROW 
select NEW.id
delete触发器

delete触发器在delete语句执行之前(before)或者执行之后(after)执行,在insert触发器代码内,可以引用一个名为"OLD" 的虚拟表,访问被删除的行。

虚拟表OLD中的值是只读的

示例

--把删除的记录存档
CREATE TRIGGER mytrigger
AFTER delete 
ON mytable
FOR EACH ROW 
begin
isnert into mytemp(id,name) values(OLD.id,OLD.name);
end;
update触发器

update触发器在update语句执行之前(before)或者执行之后(after)执行,在update触发器代码内,可以引用一个名为"OLD" 的虚拟表,访问旧记录。引用一个名为"NEW" 的虚拟表访问新更新的值。

在before update触发器中,NEW 中的值可以被更新

虚拟表OLD中的值是只读的

示例

--更新记录时,保证名字总是大小的
CREATE TRIGGER mytrigger
before update 
ON mytable
FOR EACH ROW 
begin
set NEW.NAME = Upper(NEW.NAME);
end;
http://www.lryc.cn/news/278506.html

相关文章:

  • 全志T113开发板Qt远程调试
  • 学习使用php、js脚本关闭当前页面窗口的方法
  • python 人脸检测与人脸识别
  • RT-Thread: ulog 日志 讲解和使用
  • git ssh key 配置
  • MongoDB聚合:$documents
  • 程序员英语 - 英文会议常用句型
  • UV贴图和展开初学者指南
  • 解密Path环境变量
  • git撤销提交到本地的commit
  • 使用Adobe Acrobat Pro DC给pdf文件填加水印
  • 解决:Unity : Error while downloading Asset Bundle: Couldn‘t move cache data 问题
  • SpringBoot默认配置文件
  • Flink构造宽表实时入库案例介绍
  • 【Kubernetes】K8s 查看 Pod 的状态
  • Linux系统操作命令
  • 大模型学习与实践笔记(五)
  • 100个GEO基因表达芯片或转录组数据处理之GSE126848(003)
  • 1. Presto基础
  • ChatGPT可以帮你做什么?
  • 20240111在ubuntu20.04.6下解压缩RAR格式的压缩包
  • YOLOv5改进 | 检测头篇 | ASFFHead自适应空间特征融合检测头(全网首发)
  • 第十三章 接口测试(笔记)
  • Github搭建图床 github搭建静态资源库 免费CDN加速 github搭建图床使用 jsdelivr CDN免费加速访问
  • Airtest-Selenium实操小课②:刷B站视频
  • Linux chmod命令详解
  • 求幸存数之和 - 华为OD统一考试
  • 【QML COOK】- 008-自定义属性
  • 前端页面优化做的工作
  • Spark六:Spark 底层执行原理SparkContext、DAG、TaskScheduler