一.MySQL上触发器的使用
示例:
1 CREATE TRIGGER trigger_name 2 trigger_time 3 trigger_event ON tbl_name 4 FOR EACH ROW 5 trigger_stmt
trigger_name:标识触发器名称,用户自行指定;
trigger_time:标识触发时机,取值为 BEFORE 或 AFTER;
trigger_event:标识触发事件,取值为 INSERT、UPDATE 或 DELETE;
tbl_name:标识建立触发器的表名,即在哪张表上建立触发器;
trigger_stmt:触发器程序体,可以是一句SQL语句,或者用 BEGIN 和 END 包含的多条语句。
由此可见,可以建立6种触发器,即:BEFORE INSERT、BEFORE UPDATE、BEFORE DELETE、AFTER INSERT、AFTER UPDATE、AFTER DELETE。
另外有一个限制是不能同时在一个表上建立2个相同类型的触发器,因此在一个表上最多建立6个触发器。
trigger_event 详解
MySQL 除了对 INSERT、UPDATE、DELETE 基本操作进行定义外,还定义了 LOAD DATA 和 REPLACE 语句,这两种语句也能引起上述6中类型的触发器的触发。
LOAD DATA 语句用于将一个文件装入到一个数据表中,相当与一系列的 INSERT 操作。
REPLACE 语句一般来说和 INSERT 语句很像,只是在表中有 primary key 或 unique 索引时,如果插入的数据和原来 primary key 或 unique 索引一致时,会先删除原来的数据,然后增加一条新数据,也就是说,一条 REPLACE 语句有时候等价于一条。
INSERT 语句,有时候等价于一条 DELETE 语句加上一条 INSERT 语句。
INSERT 型触发器:插入某一行时激活触发器,可能通过 INSERT、LOAD DATA、REPLACE 语句触发;
UPDATE 型触发器:更改某一行时激活触发器,可能通过 UPDATE 语句触发;
DELETE 型触发器:删除某一行时激活触发器,可能通过 DELETE、REPLACE 语句触发。
实际使用:
1 /* 2 触发器-- 在给firsttable插入一条数据的同时 给secondtable插入相同的数据 3 */ 4 CREATE TRIGGER cfq_insert_one 5 AFTER 6 INSERT 7 ON firsttable FOR EACH ROW 8 INSERT INTO secondtable SET firstname = new.firstName;/*new.firstName 就是新增加的数据*/ 9 /*展示 目标表上的触发器*/ 10 SHOW TRIGGERS LIKE ‘firsttable‘; 11 12 INSERT INTO firsttable VALUES (‘李思‘);
如果,如果你打算执行多个语句,可使用BEGIN ... END复合语句结构。
示例如下:
1 CREATE TRIGGER testref BEFORE INSERT ON test1 2 FOR EACH ROW BEGIN 3 INSERT INTO test2 SET a2 = NEW.a1; 4 DELETE FROM test3 WHERE a3 = NEW.a1; 5 UPDATE test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1; 6 END