目录
一、触发器的介绍
二、触发器的语法
(1)insert触发器
(2)update触发器
(3)delete触发器
触发器是与表有关的数据库对象,指在insert/update/delete 之前或之后,触发并执行
触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的
完整性,日志记录,数据校验等操作。
使用别名old和new来引用触发器中发生变化的记录内容,这与其它的数据库是相似的。
现在触发器还只支持行级触发,不支持语句级触发。
触发器类型 new和oldinsert型触发器 new表示将要挥着已经新增的数据update型触发器 old表示修改之前的数据,new表示将要或者已经修改后的数据delete型触发器 old表示将要或者已经删除的数据
语法:1:创建触发器语句create trigger 触发器名称 before/after insert/update/delete on 表名 for each rowbeginsql语句end;这里的after和before表示的是增删改之后还是之前触发的2:查看触发器语句show triggers;3:删除触发器drop trigger 数据库名.触发器的名字;(如果没有指定数据库的名字,那么默认是当前数据库)
create table user_logs(opera_text varchar(1000) comment '插入的·内容',opera_time datetime comment '插入的时间',opera varchar(20) comment '操作的类型,insert/delete/update');create trigger tb_user_insert_tiggerafter insert on sp for each rowbegininsert into user_logs(opera_text, opera_time, opera)values(concat('插入的名字=',new.name,',插入的年龄=',new.age),now(),'insert');end;show triggers; insert into sp(age, name) values (100,'大魔王');
create trigger tb_user_update_triggerafter update on sp for each rowbegininsert into user_logs(opera_text, opera_time, opera) values(concat('更新前的名字=',old.name,' 更新前的年龄=',old.age,' 更新后的名字=',new.name,' 更新后的年龄=',new.age),now(),'update');end; show triggers; update sp set age=1000 where name='李四';
create trigger tb_user_delete_triggerafter delete on sp for each rowbegininsert into user_logs(opera_text, opera_time, opera)values(concat('删除的名字=',old.name,' 删除前的年龄=',old.age),now(),'delete');end; show triggers; delete from sp where name='李四';
上一篇:SpringBoot利用Spring SPI机制实现自动按顺序加载注册JavaBean到容器中
下一篇:支付宝里余额宝一次性可以转多少钱(支付宝里余额宝一次性可以转多少钱到银行卡) 支付宝如何开通余额自动转余额宝 支付宝余额宝转账一次能转多少钱