欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

小贝_mysql触发器使用_MySQL

程序员文章站 2022-04-18 16:36:47
...

触发器

简要
1、触发器基本概念
2、触发器语法及实战例子
3、before和after区别

一、触发器基本概念

1、一触即发

2、作用: 监视某种情况并触发某种操作

3、观察场景

一个电子商城:

商品表,goods

主键(goods_id)

商品名称(goods_name)

库存(goods_number)

1

iphone6

10

2

小米手机

28

订单表,orders

订单主键(order_id)

商品主键(goods_id)

购买数量(buy_num)

1

2

3

2

1

4

从php的角度看,完成下单与减少库存的逻辑如下:

a、下单后,往orders表插入数据:

insert into orders(goods_id,bug_num)values(2,3);

b、修改goods对应商品的库存:

update goods setgoods_number=goods_number-3 where goods_id=2;

总结: 这两个逻辑可以看成是一个整体,或者说,insert—>触发update

处理方案: 使用触发器来解决上述问题,我们可以监视某张表的变化,当发生某种变化时,触发某个操作

4、触发器监视以及触发什么变化

a、监视update/insert/delete

b、触发update/insert/delete

二、触发器语法

1、创建语法的四个要素

小贝_mysql触发器使用_MySQL

2、创建触发器

2.1、测试案例的表结构

#商品表

create table goods

(goods_id int,goods_name varchar(10),goods_number smallint)charset=utf8;

insert into goods

values(1,'iphone6',10),(2,'小米手机',28);

#订单表

create table orders

(order_id int,goods_id int,buy_num smallint)charset=utf8;

insert into orders

values(1,2,3),(2,1,4);

2.2、创建触发器语法

小贝_mysql触发器使用_MySQL

createtrigger triggerName

after/beforeinsert/update/deleteon Table

begin

sql语句(一句或多句sql)

end;

2.3、触发器实例

2.3.1、建立触发器,往订单表orders插入数据时,更新商品表goods的库存量

小贝_mysql触发器使用_MySQL

往orders表插入数据前,各个表的数据如下

小贝_mysql触发器使用_MySQL

往orders表插入数据:

小贝_mysql触发器使用_MySQL

查看goods表的数据:

小贝_mysql触发器使用_MySQL

此时,orders表插入的是iphone6两台,但是减少的却是小米手机商品的库存。

当往orders表插入的是小米手机两台呢?

小贝_mysql触发器使用_MySQL

此时,减少的也是小米手机,但是减少的是1,而不是2

问题:出在哪里?

1、查看刚建立的触发器信息

小贝_mysql触发器使用_MySQL

原来触发的sql语句是固定某个商品id的,因此,触发只对该商品id发生作用

2、如何在触发器引用行的值?

对于insert而言,新增的行,用new来表示,行中的每一列的值,用new.列名来表示

3、修改触发器t1(删除原来重新建立)

小贝_mysql触发器使用_MySQL

4、验证结果

插入前,各个表数据如下

小贝_mysql触发器使用_MySQL

插入orders表,iPhone6三台

小贝_mysql触发器使用_MySQL

插入orders表,小米手机五台

小贝_mysql触发器使用_MySQL

2.3.2、建立触发器,往订单表orders删除数据时,更新商品表goods的库存量

a、建立触发器t2

小贝_mysql触发器使用_MySQL

b、删除orders的数据

b1、删除前,各个表数据

小贝_mysql触发器使用_MySQL

b2、删除后,各个表数据:

小贝_mysql触发器使用_MySQL

总结:

对于delete而言,如何在触发器引用行的值?

对于delete操作来说,它要操作的数据,已经是存在表中了,因此用old来表示,行中的每一列的值,用old.列名来表示

2.3.3、建立触发器,往订单表orders修改数据时,更新商品表goods的库存量

a、创建触发器t3

小贝_mysql触发器使用_MySQL

b、修改orders表数据

b1、修改前,各个表的数据

小贝_mysql触发器使用_MySQL

b2、修改后,各个表的数据

小贝_mysql触发器使用_MySQL

总结:

对于update而言,如何在触发器引用行的值?

对于update操作来说,它要操作的数据,已经是存在表中了,因此用old来引用修改前的值,修改后则为用new来引用新值

2.4、查看触发器和删除触发器语法

2.4.1、查看所有触发器

小贝_mysql触发器使用_MySQL

2.4.2、查看某个触发器

小贝_mysql触发器使用_MySQL

2.4.3、删除触发器

小贝_mysql触发器使用_MySQL

三、before与after的区别

1、区别:

a、after是先完成数据的增删改后,再触发

触发中的语句晚于增删改,无法影响前面的增删改动作

b、before是先完成触发,再增删改

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

2、案例:

对于所下订单进行判断,如果订单的数据>5,则认为是非法订单,强制把所订商品数据改成5

2.1、建立触发器

小贝_mysql触发器使用_MySQL

2.2、插入前,各个表的数据

小贝_mysql触发器使用_MySQL

2.3、插入后,各个表的数据

小贝_mysql触发器使用_MySQL


The quieter you become,the more you are able to hear!

相关标签: 小贝 触发器