时间:2021-07-01 10:21:17 帮助过:14人阅读
触发器,顾名思义,基于某具体的DML语句的触发或执行,来执行一个动作。mysql触发器在6个不同的集成点进行定义: before insert after insert before update after update before delete after delete 每个点只能定义一个触发器,触发器只可以应用在for each
触发器,顾名思义,基于某具体的DML语句的触发或执行,来执行一个动作。mysql触发器在6个不同的集成点进行定义:
before insert
after insert
before update
after update
before delete
after delete
每个点只能定义一个触发器,触发器只可以应用在for each row上,没有每个语句级的功能。
也没有代替触发器的语法。
触发器的语法:
create trigger
before |after insert|update|delete on
- delimiter //
- create trigger trigger_test_bri
- before insert on trigger_test
- for each row
- insert into logger(id,action,time) values (NEW.id, 'Insert', NOW());
- //
- create trigger trigger_test_ari
- after insert on trigger_test
- for each row
- insert into logger(id,action,time) values (NEW.id, 'Insert', NOW());
- //
- delimiter ;
更新触发器:
添加before update或者after update触发器并测试update语法:
- create trigger trigger_test_bru
- before update on trigger_test
- for each row
- insert into logger(id,action,time) values (OLD.id, 'Update', NOW());
- //
- create trigger trigger_test_aru
- after update on trigger_test
- for each row
- insert into logger(id,action,time) values(NEW.id, 'Update', NOW());
- //
- update trigger_test set id=id+10 where id=1;
如果拥有super权限,就可以指定一个用户作为触发器的定义者。默认情况下,当执行触发器时,当前用户的权限会用于底层表。可以改变这些默认设置,使特定的用户可以执行这些操作。
create [definer