MySql 触发器

https://www.cnblogs.com/fanqisoft/p/10782798.html
MySql 触发器
⒈是什么?

触发器就是某个表发生一个事件(增删改操作),然后自动的执行预先编译好的SQL语句,执行相关操作。触发器事件跟触发器中的SQL语句是原子性的(要么同时执行,要么同时不执行),这样保证了数据的完整性。

⒉创建触发器

1.语法

复制代码
drop trigger if exists databaseName.tri_Name;
create trigger tri_Name – tri_Name代表触发器名称
tirgger_time trigger_event on tableName – tirgger_time为触发时机,可选值有after/before,trigger_event为触发事件,可选值有insert/update/delete
for each row – 这句话在mysql是固定的,表示任何一条记录上的操作满足触发事件都会触发该触发器。
begin
sql语句;
end
复制代码
  2示例

①insert类型触发器

复制代码
1 drop trigger if exists study.tgr_users_insert;
2 create trigger tgr_users_insert
3 before insert on users
4 for each row
5 begin
6 set new.username=‘fanqi’; – NEW用来表示将要(before)或已经(after)插入的新数据。
7 end;
复制代码
   ②delete类型触发器

复制代码
1 drop trigger if exists study.tgr_users_delete;
2 create trigger tgr_users_delete
3 before delete on users
4 for each row
5 begin
6 declare oldusername varchar(20) default ‘fan’;
7 set oldusername = old.username; – old用来表示将要或已经被删除的原数据。
8 end;
复制代码
   ③update类型触发器

复制代码
1 drop trigger if exists study.tgr_users_update;
2 create trigger tgr_users_update
3 before update on users
4 for each row
5 begin
6 declare oldusername varchar(20) default ‘fan’;
7 set oldusername = old.username; – old用来表示将要或已经被修改的原数据
8 set new.username= concat(oldusername,new.username); – new用来表示将要或已经修改为的新数据
9 end;
复制代码
⒊查看触发器

1 show triggers from databaseName;
⒋删除触发器

1 drop trigger if exists databaseName.tri_Name;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值