源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

MySQL笔记之触发器的应用

  • 时间:2022-05-21 02:26 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:MySQL笔记之触发器的应用
[b]创建触发器 创建只有一个执行语句的触发器 [/b]
[u]复制代码[/u] 代码如下:
CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW 执行语句
其中,触发器名参数指要创建的触发器的名字 BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后 FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器
[u]复制代码[/u] 代码如下:
mysql> CREATE TRIGGER trig1 AFTER INSERT     -> ON work FOR EACH ROW     -> INSERT INTO time VALUES(NOW()); Query OK, 0 rows affected (0.09 sec)
上面创建了一个名为trig1的触发器,一旦在work中有插入动作,就会自动往time表里插入当前时间 [b]创建有多个执行语句的触发器 [/b]
[u]复制代码[/u] 代码如下:
CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW BEGIN     执行语句列表 END
其中,BEGIN与END之间的执行语句列表参数表示需要执行的多个语句,不同语句用分号隔开 tips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突      为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||      当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;
[u]复制代码[/u] 代码如下:
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) mysql> DELIMITER ;
上面的语句中,开头将结束符号定义为||,中间定义一个触发器,一旦有满足条件的删除操作 就会执行BEGIN和END中的语句,接着使用||结束 最后使用DELIMITER ; 将结束符号还原 [b]查看触发器 SHOW TRIGGERS语句查看触发器信息 [/b]
[u]复制代码[/u] 代码如下:
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
结果会显示所有触发器的基本信息 tips:SHOW TRIGGERS语句无法查询指定的触发器 [b]在triggers表中查看触发器信息 [/b]
[u]复制代码[/u] 代码如下:
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())
结果显示了所有触发器的详细信息,同时,该方法可以查询制定触发器的详细信息
[u]复制代码[/u] 代码如下:
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
[b]tips:[/b]所有触发器信息都存储在information_schema数据库下的triggers表中      可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询 [b]删除触发器 [/b]
[u]复制代码[/u] 代码如下:
mysql> DROP TRIGGER trig1; Query OK, 0 rows affected (0.04 sec)
删除触发器之后最好使用上面的方法查看一遍 同时,也可以使用database.trig来指定某个数据库中的触发器 [b]tips:[/b]如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部