答案:MySQL触发器是绑定到表的自动执行对象,用于在插入、更新或删除时执行日志记录、数据校验等操作;通过CREATE TRIGGER定义,支持BEFORE或AFTER事件时机,使用NEW和OLD引用数据,适用于维护一致性,但不宜处理复杂逻辑。
在MySQL中使用触发器可以自动执行特定操作,比如在插入、更新或删除数据时自动记录日志、验证数据或维护表间一致性。触发器是绑定到表上的数据库对象,当表发生指定事件时会自动激活。
使用 CREATE TRIGGER 语句定义触发器,基本结构如下:
CREATE TRIGGER trigger_name [BEFORE | AFTER] [INSERT | UPDATE | DELETE] ON table_name FOR EACH ROWBEGIN -- 触发器执行的SQL语句 END;
说明:
假设有一个用户表 users 和一个操作日志表 user_logs:
-- 创建日志表
CREATE TABLE user_logs (
id INT AUTO_INCREMENT PRIMARY KEY,
user_id INT,
action VARCHAR(10),
changed_at DATETIME
);
-- 创建插入后触发器
CREATE TRIGGER after_user_insert
AFTER INSERT ON users
FOR EACH ROW
BEGIN
INSERT INTO user_logs (user_id, action, changed_at)
VALUES (NEW.id, 'INSERT', NOW());
END;
当向 users 表插入一条记录时,日志表会自动记录操作信息。
再看一个数据校验的例子:
-- 插入前检查年龄
CREATE TRIGGER before_user_insert
BEFORE INSERT ON users
FOR EACH ROW
BEGIN
IF NEW.age < 0 THEN
SET NEW.age = 0;
END IF;
END;
这个触发器防止插入负数年龄,自动修正为0。
查看当前数据库中的所有触发器:
SHOW TRIGGERS;
更详细的查询方式:
SELECT * FROM information_schema.triggers WHERE trigger_schema = 'your_database_name';
删除触发器:
DROP TRIGGER IF EXISTS trigger_name;
注意:删除表时,与之关联的触发器也会被自动删除。
基本上就这些。合理使用触发器能提升数据一致性和自动化程度,但不宜过度依赖。简单、明确的业务规则更适合用触发器处理。