首页 > 数据库 > MySQL > 正文

学习笔记之MySQL触发器详解

2024-07-24 12:38:23
字体:
来源:转载
供稿:网友

触发器是由事件来触发某个操作,这些事件包括INSERT语句,UPDATE语句和DELETE语句.

创建触发器:创建只有一个执行语句的触发器.

CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件,ON 表名 FOR EACH ROW 执行语句其中,触发器名参数指要创建的触发器的名字.

1、创建MySQL触发器:

语法:代码如下:

  1. CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name  
  2.  
  3. FOR EACH ROW  
  4.  
  5. BEGIN  
  6.  
  7. trigger_stmt  
  8.  
  9. END;  
  10.  
  11. CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name 
  12.  
  13. FOR EACH ROW  
  14.  
  15. BEGIN 
  16.  
  17. trigger_stmt 
  18.  
  19. END; 

例子,代码如下:

  1. CREATE TRIGGER SetUserHome after insert ON users  
  2.  
  3. FOR EACH ROW  
  4.  
  5. BEGIN  
  6.  
  7. update `users` set homeLocationX = 128, 
  8.  
  9. homeLocationY=128, homeLocationZ=30  
  10. --Vevb.com 
  11. where uuid = NEW.uuid 
  12.  
  13. END  

以上的例子是错误的,让本表进行触发时进行更新会让程序进入死循环,系统会报这样的错误:it is already used by statement which invoked this stored function/trigger.

应该改成以下语句:

  1. CREATE TRIGGER SetUserHome before insert ON users  
  2.  
  3. FOR EACH ROW  
  4.  
  5. BEGIN  
  6.  
  7. set New.homeLocationX = 128; 
  8.  
  9. set New.homeLocationY = 128; 
  10.  
  11. set New.homeLocationZ=30;  
  12.  
  13. END 

BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后,FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器,代码如下:

  1. mysql> CREATE TRIGGER trig1 AFTER INSERT 
  2.     -> ON work FOR EACH ROW 
  3.     -> INSERT INTO time VALUES(NOW()); 

Query OK, 0 rows affected (0.09 sec)上面创建了一个名为trig1的触发器,一旦在work中有插入动作,就会自动往time表里插入当前时间.

创建有多个执行语句的触发器

CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件

ON 表名 FOR EACH ROW

BEGIN

执行语句列表

END其中,BEGIN与END之间的执行语句列表参数表示需要执行的多个语句,不同语句用分号隔开.

tips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突,为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||,当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;代码如下:

  1. mysql> DELIMITER || 
  2. mysql> CREATE TRIGGER trig2 BEFORE DELETE 
  3.     -> ON work FOR EACH ROW 
  4.     -> BEGIN 
  5.     -> INSERT INTO time VALUES(NOW()); 
  6.     -> INSERT INTO time VALUES(NOW()); 
  7.     -> END 
  8.     -> || 
  9. Query OK, 0 rows affected (0.06 sec) 

mysql> DELIMITER ;上面的语句中,开头将结束符号定义为||,中间定义一个触发器,一旦有满足条件的删除操作,就会执行BEGIN和END中的语句,接着使用||结束,最后使用DELIMITER ; 将结束符号还原.

查看触发器:

SHOW TRIGGERS语句查看触发器信息,代码如下:

  1. mysql> SHOW TRIGGERSG; 
  2. *************************** 1. row *************************** 
  3.              Trigger: trig1 
  4.                Event: INSERT 
  5.                Tablework 
  6.            Statement: INSERT INTO time VALUES(NOW()) 
  7.               Timing: AFTER 
  8.              Created: NULL 
  9.             sql_mode:  
  10.              Definer: root@localhost 
  11. character_set_client: utf8 
  12. collation_connection: utf8_general_ci 

Database Collation: latin1_swedish_ci结果会显示所有触发器的基本信息

tips:SHOW TRIGGERS语句无法查询指定的触发器

在triggers表中查看触发器信息,代码如下:

  1. mysql> SELECT * FROM information_schema.triggersG 
  2. *************************** 1. row *************************** 
  3.            TRIGGER_CATALOG: def --Vevb.com 
  4.             TRIGGER_SCHEMA: person 
  5.               TRIGGER_NAME: trig1 
  6.         EVENT_MANIPULATION: INSERT 
  7.       EVENT_OBJECT_CATALOG: def 
  8.        EVENT_OBJECT_SCHEMA: person 
  9.         EVENT_OBJECT_TABLE: work 
  10.               ACTION_ORDER: 0 
  11.           ACTION_CONDITION: NULL 
  12.           ACTION_STATEMENT: INSERT INTO time VALUES(NOW())  

结果显示了所有触发器的详细信息,同时,该方法可以查询制定触发器的详细信息,代码如下:

  1. mysql> SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME='trig1'
  2. *************************** 1. row *************************** 
  3.            TRIGGER_CATALOG: def 
  4.             TRIGGER_SCHEMA: person 
  5.               TRIGGER_NAME: trig1 
  6.         EVENT_MANIPULATION: INSERT 
  7.       EVENT_OBJECT_CATALOG: def 
  8.        EVENT_OBJECT_SCHEMA: person 
  9.         EVENT_OBJECT_TABLE: worktips  

所有触发器信息都存储在information_schema数据库下的triggers表中,可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询.

删除触发器

mysql> DROP TRIGGER trig1;

Query OK, 0 rows affected (0.04 sec)删除触发器之后最好使用上面的方法查看一遍.同时,也可以使用database.trig来指定某个数据库中的触发器

tips:如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作.

 

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表