注册 | 登录 |
地方论坛门户及新闻和人才网址大全

MySQL笔记之触发器的应用

时间:2021-07-21人气:-


创建触发器创建只有一个执行语句的触发器复制代码 代码如下:CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件ON 表名 FOR EACH ROW 执行语句其中,触发器名参数指要创建的触发器的名字BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器复制代码 代码如下: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表里插入当前时间创建有多个执行语句的触发器复制代码 代码如下:CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件ON 表名 FOR EACH ROWBEGIN执行语句列表END其中,BEGIN与END之间的执行语句列表参数表示需要执行的多个语句,不同语句用分号隔开tips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突   为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||   当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;复制代码 代码如下: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 ; 将结束符号还原查看触发器SHOW TRIGGERS语句查看触发器信息复制代码 代码如下:mysql> SHOW TRIGGERSG;*************************** 1. row ***************************Trigger: trig1Event: INSERTTable: workStatement: INSERT INTO time VALUES(NOW())Timing: AFTERCreated: NULLsql_mode:Definer: root@localhostcharacter_set_client: utf8collation_connection: utf8_general_ciDatabase Collation: latin1_swedish_ci结果会显示所有触发器的基本信息tips:SHOW TRIGGERS语句无法查询指定的触发器在triggers表中查看触发器信息复制代码 代码如下:mysql> SELECT * FROM information_schema.triggersG*************************** 1. row ***************************TRIGGER_CATALOG: defTRIGGER_SCHEMA: personTRIGGER_NAME: trig1EVENT_MANIPULATION: INSERTEVENT_OBJECT_CATALOG: defEVENT_OBJECT_SCHEMA: personEVENT_OBJECT_TABLE: workACTION_ORDER: 0ACTION_CONDITION: NULLACTION_STATEMENT: INSERT INTO time VALUES(NOW())结果显示了所有触发器的详细信息,同时,该方法可以查询制定触发器的详细信息复制代码 代码如下:mysql> SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME='trig1'G*************************** 1. row ***************************TRIGGER_CATALOG: defTRIGGER_SCHEMA: personTRIGGER_NAME: trig1EVENT_MANIPULATION: INSERTEVENT_OBJECT_CATALOG: defEVENT_OBJECT_SCHEMA: personEVENT_OBJECT_TABLE: worktips:所有触发器信息都存储在information_schema数据库下的triggers表中   可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询删除触发器复制代码 代码如下:mysql> DROP TRIGGER trig1;Query OK, 0 rows affected (0.04 sec)删除触发器之后最好使用上面的方法查看一遍同时,也可以使用database.trig来指定某个数据库中的触发器tips:如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作

上篇:MySQL笔记之别名的使用

下篇:MySQL笔记之子查询使用介绍