Mysql触发器怎么定义与使用
这篇“Mysql触发器怎么定义与使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mysql触发器怎么定义与使用”文章吧。
一、触发器的介绍
触发器是与表有关的数据库对象,指在insert/update/delete 之前或之后,触发并执行
触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的
完整性,日志记录,数据校验等操作。
使用别名old和new来引用触发器中发生变化的记录内容,这与其它的数据库是相似的。
现在触发器还只支持行级触发,不支持语句级触发。
触发器类型 new和old
insert型触发器 new表示将要挥着已经新增的数据
update型触发器 old表示修改之前的数据,new表示将要或者已经修改后的数据
delete型触发器 old表示将要或者已经删除的数据
二、触发器的语法
语法:
1:创建触发器语句
create trigger 触发器名称 before/after insert/update/delete on 表名 for each row
begin
sql语句
end;
这里的after和before表示的是增删改之后还是之前触发的
2:查看触发器语句
show triggers;
3:删除触发器
drop trigger 数据库名.触发器的名字;(如果没有指定数据库的名字,那么默认是当前数据库)
(1)insert触发器
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_tigger after insert on sp for each row begin insert 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,'大魔王');
(2)update触发器
create trigger tb_user_update_trigger after update on sp for each row begin insert 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='李四';
(3)delete触发器
create trigger tb_user_delete_trigger after delete on sp for each row begin insert into user_logs(opera_text, opera_time, opera) values(concat('删除的名字=',old.name,' 删除前的年龄=',old.age),now(),'delete'); end;show triggers;delete from sp where name='李四';
以上就是关于“Mysql触发器怎么定义与使用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341