mysql 、sql server trigger 触发器

sql server

mySQL

复制代码
create trigger 触发器名称
{ before | after }  [ insert | update | delete ] on  表名
for each  row
触发器执行的语句块

## 表名:  表示触发器监控的对象
## before |  after :  表示触发的时间,before  :  表示在事件之前触发;  after:表示在事件之后触发
##  insert  |   update  |  delete :表示触发的事件
      Insert: 表示插入记录时触发
      update: 表示更新记录时触发
      delete:表示删除记录时触发
 ## 触发器执行语句块:  可以是单条sql语句,也可以有 begin  。。。。end  结构组成的复合语句块,注意要加 delimiter  $   .....delimiter ;

NEW与OLD详解

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

在INSERT型触发器中,NEW用来表示将要(BEFORE)或已经(AFTER)插入的新数据;

在UPDATE型触发器中,OLD用来表示将要或已经被修改的原数据,NEW用来表示将要或已经修改为的新数据;

在DELETE型触发器中,OLD用来表示将要或已经被删除的原数据;

使用方法:

NEW.columnname:新增行的某列数据(columnName为相应数据表某一列名)

OLD.columnname:删除行的某列数据(columnName为相应数据表某一列名)

另外,OLD是只读的,而NEW则可以在触发器中使用 SET 赋值,这样不会再次触发触发器,造成循环调用

sql server Insertded 等价 Mysql NEW deleted表 等价 OLD 表

查看触发器

1、SHOW TRIGGERS语句查看触发器信息

#查询所有触发器

SHOW TRIGGERS

查看指定触发器定义

show create trigger 触发器名称

结果,显示所有触发器的基本信息;无法查询指定的触发器

2、在information_schema.triggers表中查看指定触发器信息

#查询指定触发器

SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME='trig1';

结果,显示所有触发器的详细信息;同时,该方法可以查询制定触发器的详细信息。

Tips:所有触发器信息都存储在information_schema数据库下的triggers表中,可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询。

删除触发器

DROP TRIGGER [IF EXISTS] [schema_name.]trigger_name

复制代码
#删除指定触发器
drop trigger  trig1;

总结

触发器是基于触发的,所以删除、新增或者修改操作可能都会激活触发器,所以不要编写过于复杂的触发器,也不要增加过多的触发器,这样会对数据的插入、修改或者删除带来比较严重的影响,同时也会带来可移植性差的后果,所以在设计触发器的时候一定要有所考虑。

触发器是一种特殊的存储过程,它在插入,删除或修改特定表中的数据时触发执行,它比数据库本身标准的功能有更精细和更复杂的数据控制能力。

相关推荐
NaiLuo_4530 分钟前
MySQL基本查询
数据库·mysql
刺客xs31 分钟前
MYSQL数据库------多表查询
数据库·mysql
曹牧41 分钟前
Oracle:拼音码
数据库·oracle
BD_Marathon42 分钟前
【JavaWeb】日程管理03——准备数据库和实体类
数据库·oracle
卡尔特斯43 分钟前
Windows MySQL 8.4 配置指南、用户创建、权限管理
mysql
大学生资源网44 分钟前
java毕业设计之面向校园的助力跑腿系统设计与实现源码(源码+文档+数据库)
java·数据库·mysql·毕业设计·源码·springboot
听到微笑1 小时前
初探Nebula Graph核心架构设计
数据库·图数据库·nebula graph
他是龙5512 小时前
43:SQL注入进阶(请求类型、方法与格式实战)
数据库·sql
卡尔特斯2 小时前
Mac Mysql 快速安装与可视化(详细流程)
mysql
木卫二号Coding2 小时前
affine+docker+postgresql+备份数据库
数据库·docker·容器