触发器是指在某个事件之前或之后执行某些特定的操作。触发器的动作时间有BEFOR和AFTER,这表示在数据库表的某一行发生修改事件之前或之后调用。
触发器三个事件:INSERT,DELETE 和 UPDATE。INSERT:表示通过INSERT,REPLACE或LOAD DATE插入一行时调用触发器
UPDATE:表示在执行 UPDATE 语句时执行触发器
DELETE:表示在执行 DELETE 或 REPLACE 语句时执行触发器
可以使用多个触发器,并通过 FOLLOWS 或PRECEDES 关键字指定触发器调用的先后顺序。
例如,对 salaries 表中的 sarary 在插入时进行四舍五入处理后再插入,创建一个BEFOR INSERT触发器:shell> vi before_insert_trigger.sql
DROP TRIGGER IF EXISTS salary_round;
DELIMITER $$
CREATE TRIGGER salary_round BEFORE INSERT ON salaries
FOR EACH ROW
BEGIN
SET NEW.salary=ROUND(NEW.salary);
END
$$
DELIMITER ;
通过SOURCE语句创建触发器:mysql> SOURCE before_insert_trigger.sql;
Query OK, 0 rows affected (0.06 sec)
Query OK, 0 rows affected (0.00 sec)
测试这个触发器:mysql> INSERT INTO salaries VALUES(10002, 100000.79,
CURDATE(), '9999-01-01');
Query OK, 1 row affected (0.04 sec)
mysql> SELECT * FROM salaries WHERE emp_no=10002 AND
from_date=CURDATE();
+--------+--------+------------+------------+
| emp_no | salary | from_date | to_date |
+--------+--------+------------+------------+
| 10002 | 100001 | 2017-06-18 | 9999-01-01 |
+--------+--------+------------+------------+
1 row in set (0.00 sec)
创建一个BEFORE UPDATE 触发器:# 选创建一张表
mysql> CREATE TABLE salary_audit (emp_no int, user
varchar(50), date_modified date);
# 再创建一个触发器,注意是在salary_round之前执行的,所以使用了 PRECEDES
shell> vi before_insert_trigger.sql
DELIMITER $$
CREATE TRIGGER salary_audit
BEFORE INSERT
ON salaries FOR EACH ROW PRECEDES salary_round
BEGIN
INSERT INTO salary_audit VALUES(NEW.emp_no,
USER(), CURDATE());
END; $$
DELIMITER ;
创建并测试:mysql> INSERT INTO salaries VALUES(10003, 100000.79,
CURDATE(), '9999-01-01');
Query OK, 1 row affected (0.06 sec)
mysql> SELECT * FROM salary_audit WHERE emp_no=10003;
+--------+----------------+---------------+
| emp_no | user | date_modified |
+--------+----------------+---------------+
| 10003 | root@localhost | 2017-06-18 |
+--------+----------------+---------------+
1 row in set (0.00 sec)
查看所有触发器:
SHOW TRIGGERS\G
查看某个触发器:
SHOW CREATE TRIGGER \G
3896

被折叠的 条评论
为什么被折叠?



