设为首页 收藏本站
查看: 663|回复: 0

[经验分享] MySQL触发器trigger的使用

[复制链接]

尚未签到

发表于 2018-10-8 09:41:30 | 显示全部楼层 |阅读模式
  Q:什么是触发器?
  A:
  触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。

  触发器的特性:
  1、有begin end体,begin end;之间的语句可以写的简单或者复杂
  2、什么条件会触发:I、D、U
  3、什么时候触发:在增删改前或者后
  4、触发频率:针对每一行执行
  5、触发器定义在表上,附着在表上。
  也就是由事件来触发某个操作,事件包括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:
  如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作,这很关键。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-616153-1-1.html 上篇帖子: MySQL存储写入速度慢分析 下篇帖子: mysql的所有权限
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表