文档章节

mysql数据库触发器

wayhk
 wayhk
发布于 2015/05/13 14:22
字数 1190
阅读 9
收藏 1
点赞 0
评论 0

触发器:
我们可以监视某表的变化,当发生某种变化时,触发某个操作
能监视:增,删,改
触发操作:增,删,改


触发器应用场景:
1.当向一张表中添加或删除记录时,需要在相关表中进行同步操作。
比如,当一个订单产生时,订单所购的商品的库存量相应减少。

2.当表上某列数据的值与其他表中的数据有联系时。
比如,当某客户进行欠款消费,
可以在生成订单时通过设计触发器判断该客户的累计欠款是否超出了最大限度。

3.当需要对某张表进行跟踪时。
比如,当有新订单产生时,需要及时通知相关人员进行处理,
此时可以在订单表上设计添加触发器加以实现



案例如下:

例一、

增加一个订单  库存相对减少  使用触发器解决问题

create table g(
id int,
name varchar(10),
num int
)charset utf8;

create table o(
oid int,
gid int,
much int
)charset utf8;


insert into g
values 
(1,'猪',22),
(2,'羊',19),
(3,'狗',12),
(4,'猫',8);


g表查询结果如图1:


通过触发器:
监视地点:o表
监视操作:insert
触发操作:update
触发时间:after

创建触发器的语法:
create trigger triggerName 
after/before insert/update/delete on表名
for each row  #这句话是固定的
begin
sql语句    # 一句或多句,insert/update/delete范围内
end;


delimiter $  告诉服务器以什么符号结束  默认是一“;”结束 这里是以“$”结束

create trigger tg1
after insert on o
for each row
begin
update g set num = num - 3 where id = 2;
 #这里必须用“;”但是mysql遇见;结束  所以说要修改结束符
end$  
告诉触发器以什么符号结束 这里是$结束
这个触发器不够完美 修改有局限性

然后操作触发器 insert into o values (2,2,3)$
此时g表查询结果如图2:


删除触发器的语法:
drop trigger 触发器名;(drop trigger tg1;)

如何在触发器引用行的值
对于insert而言,新增的行 用new来表示
行中的每一列的值,用 new.列名 表示


create trigger tg2
after insert on o
for each row 
begin 
update g set num = num - new.much where id = new.gid;
end$


没有操作之前的g表信息如图3:

操作触发器
insert into o values (1,4,2);
此时如图4:

可见触发器已经起作用  

例二、

删除一个订单,库存相应增加


监视地点:o表
监视事件:delete
触发事件:update
触发时间:after


对于delete而言,原本有一行,后来被删除,
想引用被删除的这一行,用old来表示,old.列名  就可以引用被删除行中的值


create trigger tg3
after delete on o
for each row
begin 
update g set num = num + old.much where id = old.gid;
end$

没有触发之前
g表信息如图5:

o表信息如图6:


操作触发器:
delete from o where oid = 1$
此时g表信息如图7:


例三、
修改订单的数量,改变库存的触发器
对于update来说
被修改的行,
修改前的数据,用old来表示,old.列名 引用被修改之前行中的值
修改后的数据,用new来表示,new.列名 引用被修改之后行中的值


create trigger tg4
after update on o
for each row 
begin
update g set num = num + old.much - new.much where id = old.gid;
end$


修改前g表的数据如图8:


o表的数据如图9:


操作触发器后:

update o set much = 7 where oid = 1;

g表的数据如图10:

o表的数据如图11:



触发器里after和before的区别
after是先安完成数据的增,删,改再触发
触发的语句晚于监视的增,删,改,无法影响前面的增删改动作

before是先完成触发,再增删改
触发的语句先于监视的增删改发生,我们有机会判断,修改即将发生的操作



典型案例
对于所下订单,进行判断,如果订单的数量>5,就认为是恶意订单,
强制把所订的商品数量改成5

create trigger tg5
before insert on o
for each row
begin
   if new.much > 5 then
       set new.much = 5;
   end if;
   update g set num = num - new.much where id = new.gid;
end$

查看g表的所有数据 如图1:


查看o表的所有数据 如图2:


触发触发器:
insert into o values (1,1,100)$
此时查看g表的所有数据 如图3:


查看o表的所有数据 如图4:


此时可以看出用before可以判断


查看所有的触发器
show triggers;

特别注意:使用触发器要修改结束符“;”一般修改成“$”

delimiter $  这个语句结束不能加;否则认为是$;结束


本文转载自:http://blog.csdn.net/huangjianxiang1875/article/details/7885130

共有 人打赏支持
wayhk
粉丝 1
博文 36
码字总数 17367
作品 0
海淀
程序员
十一、MySQL触发器

MySQL的触发器和存储过程一样,都是嵌入到MySQL的一段程序。触发器是由时间来触发某个操作,这些时间包括INSERT、UODATE和DELETE语句。如果定义了触发程序,当数据库执行这些语句的时候就会触...

运维菜鸟丶 ⋅ 2017/08/05 ⋅ 0

自动生成mysql触发器代码,实现数据同步

自动生成mysql触发器代码,实现数据同步 如果公司里有上百个表要做触发器,如果手动写代码的话。很累,所以今天写了一个小程序,自动生成mysql的触发代码。 $dbname = 'test';//数据库 $tab1 ...

刘赤龙 ⋅ 2010/06/08 ⋅ 0

mysql-之触发器_已迁移

mysql 触发器 当发生某个事件(增删更查)时可以执行定义的sql语句 ===============总结 无情的分隔线 总结======================== 一、触发器作用 MySQL包含对触发器的支持。触发器是一种与...

鬼谷子灬 ⋅ 2016/06/29 ⋅ 0

【数据库】触发器详解

1 引言 Mysql的触发器和存储过程一样,都是嵌入到mysql的一段程序。触发器是mysql5新增的功能,目前线上凤巢系统、北斗系统以及哥伦布系统使用的数据库均是mysql5.0.45版本,很多程序比如fc-...

磊神Ray ⋅ 2012/02/23 ⋅ 1

mysql存储过程入门与提高(第一篇)

以前在网上看到歪国人专门写了本mysql存储过程,感觉很强大啊。 MySQL stored programs包括存储过程,函数,触发器。 主要有三种类型的数据库存储程序 存储过程 存储过程是最常见的存储程序,...

落叶刀 ⋅ 2015/09/23 ⋅ 0

MySQL的触发器

触发器—trigeer是数据库下用于监视数据改变的某种情况,并触发执行某种操作的一个功能,简单来说就是对某一张表符合某种条件的更改前或者后执行一段存储过程。在这里就简单的说一说在MySQL...

往事_Jim_遗 ⋅ 01/08 ⋅ 0

一次mysql 用户不存在的报错

前阵回收生产帐号的访问范围,即之前是xxx@"%"的帐号命名方式,修改成若干个以前端应用部署的机器IP为准,修改成xxx@"IP address"。尽量减少不可信客户端连接数据库的情况发生,加强数据安全...

Jenkin_lin ⋅ 2017/03/26 ⋅ 0

MySQL之存储过程.触发器学习整理

前几天去参加腾讯的面试,在一面中,面试官问了一个问题:会用数据库吗?我说基本的会,然后他说:现在写一个删除一列的sql语句,然后就尴尬了。。。 回来后,决定好好把基本的sql语句好好学...

一宁 ⋅ 2012/04/25 ⋅ 3

《MySQL必知必会》读书笔记(四) 22~30章 完结篇

1、视图 视图不包含表中应该有的任何列或数据,它包含的是一个SQL查询。在视图创建之后,可以用于表基本相同的方式利用它们。可以对视图执行SELECT操作,过滤和排序数据,将视图联结到其他视...

一万 ⋅ 2016/02/08 ⋅ 0

MySQL触发器trigger的使用

Q:什么是触发器? A:   触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。 触发器的特性:   1、有begin end体,begin end;之间的语句可以写的简单...

zsdnr ⋅ 2017/07/21 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

vbs 取文件大小 字节

dim namedim fs, s'name = Inputbox("姓名")'msgbox(name)set fs = wscript.createobject("scripting.filesystemobject") 'fs为FSO实例if (fs.folderexists("c:\temp"))......

vga ⋅ 10分钟前 ⋅ 1

高并发之Nginx的限流

首先Nginx的版本号有要求,最低为1.11.5 如果低于这个版本,在Nginx的配置中 upstream web_app { server 到达Ip1:端口 max_conns=10; server 到达Ip2:端口 max_conns=10; } server { listen ...

算法之名 ⋅ 今天 ⋅ 0

Spring | IOC AOP 注解 简单使用

写在前面的话 很久没更新笔记了,有人会抱怨:小冯啊,你是不是在偷懒啊,没有学习了。老哥,真的冤枉:我觉得我自己很菜,还在努力学习呢,正在学习Vue.js做管理系统呢。即便这样,我还是不...

Wenyi_Feng ⋅ 今天 ⋅ 0

博客迁移到 https://www.jianshu.com/u/aa501451a235

博客迁移到 https://www.jianshu.com/u/aa501451a235 本博客不再更新

为为02 ⋅ 今天 ⋅ 0

win10怎么彻底关闭自动更新

win10自带的更新每天都很多,每一次下载都要占用大量网络,而且安装要等得时间也蛮久的。 工具/原料 Win10 方法/步骤 单击左下角开始菜单点击设置图标进入设置界面 在设置窗口中输入“服务”...

阿K1225 ⋅ 今天 ⋅ 0

Elasticsearch 6.3.0 SQL功能使用案例分享

The best elasticsearch highlevel java rest api-----bboss Elasticsearch 6.3.0 官方新推出的SQL检索插件非常不错,本文一个实际案例来介绍其使用方法。 1.代码中的sql检索 @Testpu...

bboss ⋅ 今天 ⋅ 0

informix数据库在linux中的安装以及用java/c/c++访问

一、安装前准备 安装JDK(略) 到IBM官网上下载informix软件:iif.12.10.FC9DE.linux-x86_64.tar放在某个大家都可以访问的目录比如:/mypkg,并解压到该目录下。 我也放到了百度云和天翼云上...

wangxuwei ⋅ 今天 ⋅ 0

PHP语言系统ZBLOG或许无法重现月光博客的闪耀历史[图]

最近在写博客,希望通过自己努力打造一个优秀的教育类主题博客,名动江湖,但是问题来了,现在写博客还有前途吗?面对强大的自媒体站点围剿,还有信心和可能型吗? 至于程序部分,我选择了P...

原创小博客 ⋅ 今天 ⋅ 0

IntelliJ IDEA 2018.1新特性

工欲善其事必先利其器,如果有一款IDE可以让你更高效地专注于开发以及源码阅读,为什么不试一试? 本文转载自:netty技术内幕 3月27日,jetbrains正式发布期待已久的IntelliJ IDEA 2018.1,再...

Romane ⋅ 今天 ⋅ 0

浅谈设计模式之工厂模式

工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 在工厂模式中,我们在创建对象时不会对客户端暴露创建逻...

佛系程序猿灬 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部