MySQL触发器是用于在数据表上自动执行SQL代码的对象。触发器会在指定的数据库事件发生之前或之后触发,这些事件包括:
- INSERT:向表中插入数据之前或之后;
- UPDATE:更新表中的数据之前或之后;
- DELETE:从表中删除数据之前或之后。
触发器的主要作用:
1. 审计跟踪:可以触发器来记录表上的数据变化情况,用于审计。
2. 数据校验:可以在改变数据之前确保数据满足某些条件。
3. 自动生成值:可以在插入数据之前自动生成一些值,如时间戳。
4. 同步操作:在改变数据之后可以自动在其他表更新相应的数据。
MySQL创建触发器的语法:
sql
CREATE TRIGGER trigger_name
{BEFORE | AFTER}
{INSERT | UPDATE | DELETE}
ON table_name
FOR EACH ROW
BEGIN
-- SQL语句
END;
示例:
sql
-- 创建触发器,在插入user表之前,记录用户信息到log表
CREATE TABLE user(
id INT,
name VARCHAR(20)
);
CREATE TABLE log(
id INT,
info VARCHAR(50)
);
CREATE TRIGGER before_insert_user
BEFORE INSERT ON user
FOR EACH ROW
BEGIN
INSERT INTO log(id, info)
VALUES(new.id, CONCAT('User ', new.name, ' inserted'));
END;
-- 插入用户,将自动记录信息到log表
INSERT INTO user(id, name) VALUES(1, 'John');
修改和删除触发器:
sql
-- 修改触发器
ALTER TRIGGER trigger_name ...
-- 删除触发器
DROP TRIGGER trigger_name;
MySQL触发器是一个很有用的功能,可以实现自动执行SQL代码,审计跟踪和数据校验等功能。触发器的使用,可以大大提高数据库程序的易用性和健壮性。