MySQL触发器

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代码,审计跟踪和数据校验等功能。触发器的使用,可以大大提高数据库程序的易用性和健壮性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱编程的小白L

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值