MySQL笔记之触发器的应用
2022-11-12 09:27:57
内容摘要
这篇文章主要为大家详细介绍了MySQL笔记之触发器的应用,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
创建触发器创建只有一个执行语句
文章正文
这篇文章主要为大家详细介绍了MySQL笔记之触发器的应用,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
创建触发器创建只有一个执行语句的触发器
代码如下:
1 2 3 | <code>CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW 执行语句 </code> |
BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后
FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器
代码如下:
1 2 3 4 5 | <code>mysql> CREATE TRIGGER trig1 AFTER INSERT -> ON work FOR EACH ROW -> INSERT INTO time VALUES(NOW()); Query OK, 0 rows affected (0.09 sec) </code> |
创建有多个执行语句的触发器
代码如下:
1 2 3 4 5 6 | <code>CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW BEGIN 执行语句列表 END </code> |
tips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突
为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||
当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;
代码如下:
1 2 3 4 5 6 7 8 9 | <code>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 -> || Query OK, 0 rows affected (0.06 sec)</code> |
mysql> DELIMITER ;
就会执行BEGIN和END中的语句,接着使用||结束
最后使用DELIMITER ; 将结束符号还原
查看触发器SHOW TRIGGERS语句查看触发器信息
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | <code>mysql> SHOW TRIGGERS\G; *************************** 1. row *************************** Trigger: trig1 Event: INSERT Table: work Statement: INSERT INTO time VALUES(NOW()) Timing: AFTER Created: NULL sql_mode: Definer: root@localhost character_set_client: utf8 collation_connection: utf8_general_ci Database Collation: latin1_swedish_ci </code> |
tips:SHOW TRIGGERS语句无法查询指定的触发器
在triggers表中查看触发器信息
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 | <code>mysql> SELECT * FROM information_schema.triggers\G *************************** 1. row *************************** TRIGGER_CATALOG: def TRIGGER_SCHEMA: person TRIGGER_NAME: trig1 EVENT_MANIPULATION: INSERT EVENT_OBJECT_CATALOG: def EVENT_OBJECT_SCHEMA: person EVENT_OBJECT_TABLE: work ACTION_ORDER: 0 ACTION_CONDITION: NULL ACTION_STATEMENT: INSERT INTO time VALUES(NOW()) </code> |
代码如下:
1 2 3 4 5 6 7 8 9 10 | <code>mysql> SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME= 'trig1' \G *************************** 1. row *************************** TRIGGER_CATALOG: def TRIGGER_SCHEMA: person TRIGGER_NAME: trig1 EVENT_MANIPULATION: INSERT EVENT_OBJECT_CATALOG: def EVENT_OBJECT_SCHEMA: person EVENT_OBJECT_TABLE: work </code> |
可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询
删除触发器
代码如下:
1 2 3 | <code>mysql> DROP TRIGGER trig1; Query OK, 0 rows affected (0.04 sec) </code> |
同时,也可以使用database.trig来指定某个数据库中的触发器
tips:如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作
注:关于MySQL笔记之触发器的应用的内容就先介绍到这里,更多相关文章的可以留意
代码注释