搜索
首页数据库mysql教程小贝_mysql触发器使用_MySQL

触发器

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

 

一、触发器基本概念

1、一触即发

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

3、观察场景

一个电子商城:

商品表,goods

主键(goods_id)

商品名称(goods_name)

库存(goods_number)

1

iphone6

10

2

小米手机

28

主键(goods_id)

商品名称(goods_name)

订单主键(order_id)

商品主键(goods_id)

购买数量(buy_num)

1

2

3

2

1

4

库存(goods_number)

1

iphone6

10

2

小米手机

28

 

订单表,orders

订单主键(order_id)

商品主键(goods_id)

购买数量(buy_num)

2

#商品表

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);

1
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、创建语法的四个要素 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、创建触发器语法

 

createtrigger triggerName

after/beforeinsert/update/deleteon Table

begin

sql语句(一句或多句sql)

end;

2.3、触发器实例

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

 

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

 

往orders表插入数据:

 

查看goods表的数据:

 

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

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

 

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

问题:出在哪里?

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

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

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

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

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

4、验证结果

插入前,各个表数据如下

插入orders表,iPhone6三台

插入orders表,小米手机五台

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

a、建立触发器t2

b、删除orders的数据

b1、删除前,各个表数据

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

总结:

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

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

 

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

a、创建触发器t3

b、修改orders表数据

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

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

总结:

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

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

 

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

2.4.1、查看所有触发器

 

2.4.2、查看某个触发器

 

2.4.3、删除触发器

 

三、before与after的区别

1、区别:

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

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

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

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

2、案例:

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

2.1、建立触发器

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

 

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

 


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

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何隐藏文本直到在 Powerpoint 中单击如何隐藏文本直到在 Powerpoint 中单击Apr 14, 2023 pm 04:40 PM

如何在 PowerPoint 中的任何点击之前隐藏文本如果您希望在单击 PowerPoint 幻灯片上的任意位置时显示文本,那么设置起来既快速又容易。要在 PowerPoint 中单击任何按钮之前隐藏文本:打开您的 PowerPoint 文档,然后单击“插入 ”菜单。单击新幻灯片。选择空白或其他预设之一。仍然在插入菜单中,单击文本框。在幻灯片上拖出一个文本框。单击文本框并输入您

oracle如何添加触发器oracle如何添加触发器Dec 12, 2023 am 10:17 AM

在Oracle数据库中,您可以使用CREATE TRIGGER语句来添加触发器。触发器是一种数据库对象,它可以在数据库表上定义一个或多个事件,并在事件发生时自动执行相应的操作。

如何使用MySQL的触发器实现数据的自动归档如何使用MySQL的触发器实现数据的自动归档Aug 02, 2023 am 10:37 AM

如何使用MySQL的触发器实现数据的自动归档引言:在现代数据管理领域,数据的自动归档和清理是一个重要而又常见的需求。随着数据量的增加,保留完整的历史数据会占用过多的存储资源,并且会降低查询性能。MySQL的触发器提供了实现这一需求的有效方法。本文将介绍如何使用MySQL的触发器来实现数据的自动归档。一、什么是MySQL的触发器MySQL的触发器是一种特殊的存

mysql的触发器是什么级的mysql的触发器是什么级的Mar 30, 2023 pm 08:05 PM

mysql的触发器是行级的。按照SQL标准,触发器可以分为两种:1、行级触发器,对于修改的每一行数据都会激活一次,如果一个语句插入了100行数据,将会调用触发器100次;2、语句级触发器,针对每个语句激活一次,一个插入100行数据的语句只会调用一次触发器。而MySQL中只支持行级触发器,不支持预语句级触发器。

如何在MySQL中使用C#编写自定义存储过程、触发器和函数如何在MySQL中使用C#编写自定义存储过程、触发器和函数Sep 20, 2023 pm 12:04 PM

如何在MySQL中使用C#编写自定义存储过程、触发器和函数MySQL是一种广泛使用的开源关系型数据库管理系统,而C#是一种强大的编程语言,对于需要与数据库进行交互的开发任务来说,MySQL和C#是很好的选择。在MySQL中,我们可以使用C#编写自定义存储过程、触发器和函数,来实现更加灵活和强大的数据库操作。本文将引导您使用C#编写并执

如何在MySQL中使用PHP编写自定义触发器和存储过程如何在MySQL中使用PHP编写自定义触发器和存储过程Sep 20, 2023 am 11:25 AM

如何在MySQL中使用PHP编写自定义触发器和存储过程引言:在开发应用程序时,我们经常需要在数据库层面进行一些操作,如插入、更新或删除数据。MySQL是一个广泛使用的关系型数据库管理系统,而PHP是一种流行的服务器端脚本语言。本文将介绍如何在MySQL中使用PHP编写自定义触发器和存储过程,并提供具体的代码示例。一、什么是触发器和存储过程触发器(Trigg

如何在MySQL中使用PHP编写触发器如何在MySQL中使用PHP编写触发器Sep 21, 2023 am 08:16 AM

如何在MySQL中使用PHP编写触发器MySQL是一种常用的关系型数据库管理系统,而PHP是一种流行的服务器端脚本语言。在MySQL中使用PHP编写触发器可以帮助我们实现自动化的数据库操作。本文将介绍如何使用PHP来编写MySQL触发器,并提供具体的代码示例。在开始之前,确保已经安装了MySQL和PHP,并且已经建立了相应的数据库表。一、创建PHP文件和数据

如何在MySQL中使用Python编写自定义触发器如何在MySQL中使用Python编写自定义触发器Sep 20, 2023 am 11:04 AM

如何在MySQL中使用Python编写自定义触发器触发器是MySQL中的一种强大的功能,它可以在数据库中的表上定义一些自动执行的操作。而Python则是一种简洁而强大的编程语言,能够方便地与MySQL进行交互。本文将介绍如何使用Python编写自定义触发器,并提供具体的代码示例。首先,我们需要安装并导入PyMySQL库,它是Python与MySQL数据库进行

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前By尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境