触发器
首页->学习资料->微服务治理->sql教程 关键词: 发布时间:2014-12-24 10:01:06 浏览次数:1387

触发器trigger
一种编程设计,类似js的基于事件编程;
可以在某个表的每次记录上设置一个事件,从而对该表上的某此操作加以监听,一旦所监听的行为出现,则会执行相应的代码;

语法
create trigger 触发器名称 触发条件,监听的内容,触发后的操作;
create trigger trigger_name
trigger_time trigger_event
on tablename for each row trigger_stmt
一共有6种事件
before insert
after  insert
before update
after  update
before delete
after  delete


例子:student表每增加一条学生记录触发一个记录操作日志的sql
create trigger test_trigger
after insert
on student for each row
insert into student_log values(null,'insert',now())


在触发程序中得到当前触发的记录信息
用new,old来获得操作前,后的记录
insrt没有旧记录,只能用new
update可以用new也可以用old
delete没有新记录,只有old可用


例子:参照上面的例子,假如我们删除一条或多条学生记录的时候,在日志里记录下此个或此批学生的id
create trigger trigger_del_student
after delete
on student for each row
insert into student_log values(null,'delete',old.id)
注意:触发器的执行是先判断触发器是否存在,存在才执行后面的sql,否则不执行;

例子:当身高大于等于1.75的学生信息被更新时,用触发器记录下此学生的id,更新前后的身高
create trigger trigger_updateheight
after update
on student for each row
if old.height>=1.75 then
insert into student_log values(null,'update',old.id,concat(old.height,'-',new.height);
end if;
由于以上语句有两个封号';'此时会出现问题;可以在创建触发器前更换最外层的分隔符,里面那个封号是没办法修改的,那样会语法错误;
则上面这个例子应该这样操作,先将分隔符改成$$然后再还原为封号";"。

delimiter $$
create trigger trigger_updateheight
after update
on student for each row
begin
if old.height>=175 then
insert into student_log values(null,'update',now(),old.id,concat(old.height,'-',new.height));
end if;
end
$$
delimiter ;

删除触发器:drop trigger 触发器名称

注意:
1、一个表上的事件只能有一个触发器,一个表最多有六个触发器,如果需要,只能将原始的删除再新增
2、只要事件发生,触发程序就可能执行,一条语句可能触发多个触发程序。
例如:下面的语句insert冲突时会进行update操作
insert into on duplicate key update

赞:(0)
踩:(0)
相关文章
find_in_set在集合中查找
sql查询自定义排序field函数
sql显示表结构及索引
sql修改表
添加、删除索引
sql分组
sql子查询
sql多表更新
sql建表同时插入数据
sql多表删除
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:607篇
浏览数:946734
粤ICP备18028092号-1  微信:hurong241