MySQL触发器trigger的使用
作者:GeaoZhang 发布时间:2024-01-23 15:08:23
一、触发器简介
1、什么是触发器?
触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。
2、触发器的特性
有
begin end
体,begin end
;之间的语句可以写的简单或者复杂什么条件会触发:I、D、U
什么时候触发:在增删改前或者后
触发频率:针对每一行执行
触发器定义在表上,附着在表上。
也就是由事件来触发某个操作,事件包括INSERT
语句,UPDATE
语句和DELETE
语句;可以协助应用在数据库端确保数据的完整性。
注意:cannot associate a trigger with a TEMPORARY table or a view.
!!尽量少使用触发器,不建议使用。
假设触发器触发每次执行1s,insert table 500
条数据,那么就需要触发500次触发器,光是触发器执行的时间就花费了500s
,而insert 500
条数据一共是1s,那么这个insert
的效率就非常低了。因此我们特别需要注意的一点是触发器的begin end
;之间的语句的执行效率一定要高,资源消耗要小。
触发器尽量少的使用,因为不管如何,它还是很消耗资源,如果使用的话要谨慎的使用,确定它是非常高效的:触发器是针对每一行的;对增删改非常频繁的表上切记不要使用触发器,因为它会非常消耗资源。
二、、创建触发器
CREATE
[DEFINER = { user | CURRENT_USER }]
TRIGGER trigger_name
trigger_time trigger_event
ON tbl_name FOR EACH ROW
[trigger_order]
trigger_body
trigger_time: { BEFORE | AFTER }
trigger_event: { INSERT | UPDATE | DELETE }
trigger_order: { FOLLOWS | PRECEDES } other_trigger_name
> BEFORE
和AFTER
参数指定了触发执行的时间,在事件之前或是之后。
> FOR EACH ROW
表示任何一条记录上的操作满足触发事件都会触发该触发器,也就是说触发器的触发频率是针对每一行数据触发一次。
> tigger_event
详解:
①INSERT型触发器
:插入某一行时激活触发器,可能通过INSERT
、LOAD DATA
、REPLACE
语句触发(LOAD DAT
语句用于将一个文件装入到一个数据表中,相当与一系列的INSERT操作);
②UPDATE型触发器
:更改某一行时激活触发器,可能通过UPDATE
语句触发;
③DELETE型触发器
:删除某一行时激活触发器,可能通过DELETE
、REPLACE
语句触发。
> trigger_order
是MySQL5.7
之后的一个功能,用于定义多个触发器,使用follows
(尾随)或precedes
(在…之先)来选择触发器执行的先后顺序。
1、创建只有一个执行语句的触发器
CREATE TRIGGER
触发器名BEFORE|AFTER
触发事件ON
表名FOR EACH ROW
执行语句;
例1:创建了一个名为trig1的触发器,一旦在work表中有插入动作,就会自动往time表里插入当前时间
mysql> CREATE TRIGGER trig1 AFTER INSERT
-> ON work FOR EACH ROW
-> INSERT INTO time VALUES(NOW());
2、创建有多个执行语句的触发器
CREATE TRIGGER
触发器名 BEFORE|AFTER
触发事件
ON 表名 FOR EACH ROW
BEGIN
执行语句列表
END;
例2:定义一个触发器,一旦有满足条件的删除操作,就会执行BEGIN
和END
中的语句
mysql> DELIMITER ||
mysql> CREATE TRIGGER trig2 BEFORE DELETE
-> ON work FOR EACH ROW
-> BEGIN
-> INSERT INTO time VALUES(NOW());
-> INSERT INTO time VALUES(NOW());
-> END||
mysql> DELIMITER ;
3、NEW与OLD详解
MySQL
中定义了 NEW
和 OLD
,用来表示触发器的所在表中,触发了触发器的那一行数据,来引用触发器中发生变化的记录内容,具体地:
①在INSERT
型触发器中,NEW用来表示将要(BEFORE
)或已经(AFTER
)插入的新数据;
②在UPDATE
型触发器中,OLD
用来表示将要或已经被修改的原数据,NEW
用来表示将要或已经修改为的新数据;
③在DELETE
型触发器中,OLD
用来表示将要或已经被删除的原数据;
使用方法:
NEW.columnName (columnName为相应数据表某一列名)
另外,OLD
是只读的,而NEW
则可以在触发器中使用 SET
赋值,这样不会再次触发触发器,造成循环调用(如每插入一个学生前,都在其学号前加“2013”)。
例3:
mysql> CREATE TABLE account (acct_num INT, amount DECIMAL(10,2));
mysql> INSERT INTO account VALUES(137,14.98),(141,1937.50),(97,-100.00);
mysql> delimiter $$
mysql> CREATE TRIGGER upd_check BEFORE UPDATE ON account
-> FOR EACH ROW
-> BEGIN
-> IF NEW.amount < 0 THEN
-> SET NEW.amount = 0;
-> ELSEIF NEW.amount > 100 THEN
-> SET NEW.amount = 100;
-> END IF;
-> END$$
mysql> delimiter ;
mysql> update account set amount=-10 where acct_num=137;
mysql> select * from account;
+----------+---------+
| acct_num | amount |
+----------+---------+
| 137 | 0.00 |
| 141 | 1937.50 |
| 97 | -100.00 |
+----------+---------+
mysql> update account set amount=200 where acct_num=137;
mysql> select * from account;
+----------+---------+
| acct_num | amount |
+----------+---------+
| 137 | 100.00 |
| 141 | 1937.50 |
| 97 | -100.00 |
+----------+---------+
三、查看触发器
1、SHOW TRIGGERS语句查看触发器信息
mysql> SHOW TRIGGERS\G;
……
结果,显示所有触发器的基本信息;无法查询指定的触发器。
2、在information_schema.triggers表中查看触发器信息
mysql> SELECT * FROM information_schema.triggers\G
……
结果,显示所有触发器的详细信息;同时,该方法可以查询制定触发器的详细信息。
mysql> select * from information_schema.triggers
-> where trigger_name='upd_check'\G;
Tips:
所有触发器信息都存储在information_schema
数据库下的triggers
表中,可以使用SELECT
语句查询,如果触发器信息过多,最好通过TRIGGER_NAME
字段指定查询。
四、删除触发器
DROP TRIGGER [IF EXISTS] [schema_name.]trigger_name
删除触发器之后最好使用上面的方法查看一遍;同时,也可以使用database.trig
来指定某个数据库中的触发器。
Tips:
如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作,这很关键。
来源:https://www.cnblogs.com/geaozhang/p/6819648.html


猜你喜欢
- 大家好,我是了不起!在某些难以抉择得时候,我们经常要用外力来帮助我们做出选择比如,梁山出征方腊前沙场点兵,挑选先锋的场景这个时候
- 情景描述在项目开发过程中,不同项目阶段可能会有不同的分支,当创建好一个分支后,就需要将代码切换到这个分支上进行代码同步,例如将当前 orig
- 组合数据类型分类组合数据类型分为三类,第一类是集合类型,第二类是序列类型,第三类是映射类型集合类型集合类型是一个元素集合,元素之间没有排列顺
- 1、手上目前拥有数据集是一大坨,没有train,test,val的划分如图所示2、目录结构:|---data |
- 前言前面我们讲过了error类型来处理一般的错误,本文会描述使用panic函数和recover函数来处理比较极端的错误。简单来说,当程序运行
- 一、打开命令提示符方法一:window+R键 ——输入cmd方法二:在此搜索cmd进入命令提示符二、
- 对于有的vps,系统默认安装了mysql。我们需要从我们的服务器、vps上卸载(移除)默认的mysql。那么如何(怎样)在ubuntu\De
- 环境:win7+python3.5(anaconda3)理论上,win7及以上的系统和python任意版本均可。一、基础脚本首先我们构建一个
- 一、打开摄像头import cv2import numpy as npdef video_demo(): capture = c
- 目标:目标文件为一个float32型存储的二进制文件,按列优先方式存储。本文使用Python读取该二进制文件并使用matplotlib.py
- 代码import psutilprint(dir(psutil))# 查看逻辑cpu的个数print(psutil.cpu_count())
- 数据库是应用开发中必须要掌握的技巧,通常在数据库开发过程中,会有两种不同的方式:直接使用SQL语句,这种方式下,直接编写SQL,简单直观,但
- 一、前期准备1、安装好python3,可以在anaconda中安装python3。2、一个合适的双目摄像头。3、一台可以运行Matlab的电
- 本文实例讲述了JS模拟实现哈希表及应用。分享给大家供大家参考,具体如下:在算法中,尤其是有关数组的算法中,哈希表的使用可以很好的解决问题,所
- JS获取多选框checkbox被选中的个数。var checkbox = document.getElementsByName("
- 今天遇到一个奇怪的现象,使用tensorflow-gpu的时候,出现内存超额~~如果我训练什么大型数据也就算了,关键我就写了一个y=W*x…
- 关于Markdown在刚才的导语里提到,Markdown 是一种用来写作的轻量级「标记语言」,它用简洁的语法代替排版,而不像一般我们用的字处
- 今天我们将介绍处理大量数据时非常方便的工具。我不会只告诉您可能在手册中找到的一般信息,而是分享一些我发现的小技巧,例如tqdm与 multi
- 前言:在页面操作过程中有时候点击某个链接会弹出新的窗口,但由于Selenium的所有操作都是在第一个打开的页面进行的,这时就需要主机切换到新
- goroutine 泄漏和避免泄漏的最佳实践Go的奇妙之处在于,我们可以使用goroutines和channel轻松地执行并发任务。如果在生