广告
返回顶部
首页 > 资讯 > 数据库 >MySQL数据库触发器trigger怎么使用
  • 504
分享到

MySQL数据库触发器trigger怎么使用

2023-07-02 10:07:39 504人浏览 独家记忆
摘要

这篇文章主要讲解了“MySQL数据库触发器trigger怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql数据库触发器trigger怎么使用”吧!一、基本概念触发器是一种特殊类

这篇文章主要讲解了“MySQL数据库触发器trigger怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql数据库触发器trigger怎么使用”吧!

    一、基本概念

    触发器是一种特殊类型的存储过程,触发器通过事件进行触发而被执行

    触发器 trigger 和js事件类似

    1、作用

    • 写入数据表前,强制检验或转换数据(保证数据安全

    • 触发器发生错误时,异动的结果会被撤销(事务安全)

    • 部分数据库管理系统可以针对数据定义语言DDL使用触发器,称为DDL触发器

    • 可以依照特定的情况,替换异动的指令 instead of(mysql不支持)

    2、触发器的优缺点

    2.1、优点
    • 触发器可通过数据库中的相关表实现级联更改(如果一张表的数据改变,可以利用触发器实现对其他表的操作,用户不知道)

    • 保证数据安全,进行安全校验

    2.2、缺点
    • 对触发器过分依赖,势必影响数据库的结构,同时增加了维护的复杂度

    • 造成数据在程序层面不可控

    二、创建触发器

    1、基本语法

    create trigger 触发器名字 触发时机 触发事件 on 表 for each rowbeginend

    2、触发对象

    on 表 for each row 触发器绑定表中所有行,没一行发生指定改变的时候,就会触发触发器

    3、触发时机

    每张表对应的行都有不同的状态,当sql指令发生的时候,都会令行中数据发生改变,每一行总会有两种状态:数据操作前和数据操作后

    • before: 数据发生改变前的状态

    • after: 数据已经发生改变后的状态

    4、触发事件

    mysql中触发器针对的目标是数据发生改变,对应的操作只有写操作(增删改)

    • inert 插入操作

    • update 更新操作

    • delete 删除操作

    5、注意事项

    一张表中,每一个触发时机绑定的触发事件对应的触发器类型只能有一个

    一张表表中只能有一个对应的after insert 触发器

    最多只能有6个触发器

    before insertafter insertbefore updateafter updatebefore deleteafter delete
    需求:

    下单减库存

    有两张表,一张是商品表,一张是订单表(保留商品ID)每次订单生成,商品表中对应的库存就应该发生变化

    创建两张表:

    create table my_item(    id int primary key auto_increment,    name varchar(20) not null,    count int not null default 0) comment '商品表';create table my_order(    id int primary key auto_increment,    item_id int not null,    count int not null default 1) comment '订单表';insert my_item (name, count) values ('手机', 100),('电脑', 100), ('包包', 100);mysql> select * from my_item;+----+--------+-------+| id | name   | count |+----+--------+-------+|  1 | 手机   |   100 ||  2 | 电脑   |   100 ||  3 | 包包   |   100 |+----+--------+-------+3 rows in set (0.00 sec)mysql> select * from my_order;Empty set (0.02 sec)

    创建触发器:

    如果订单表发生数据插入,对应的商品就应该减少库存

    delimiter $$create trigger after_insert_order_trigger after insert on my_order for each rowbegin    -- 更新商品库存    update my_item set count = count - 1 where id = 1;end$$delimiter ;

    三、查看触发器

    -- 查看所有触发器show triggers\G*************************** 1. row ***************************             Trigger: after_insert_order_trigger               Event: INSERT               Table: my_order           Statement: begin    update my_item set count = count - 1 where id = 1;end              Timing: AFTER             Created: 2022-04-16 10:00:19.09            sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISioN_BY_ZERO,NO_ENGINE_SUBSTITUTION             Definer: root@localhostcharacter_set_client: utf8mb4collation_connection: utf8mb4_general_ci  Database Collation: utf8mb4_general_ci1 row in set (0.00 sec)-- 查看创建语句show crate trigger 触发器名字;-- eg:show create trigger after_insert_order_trigger;

    四、触发触发器

    让触发器执行,让触发器指定的表中,对应的时机发生对应的操作

    insert into my_order (item_id, count) values(1, 1);mysql> select * from my_order;+----+---------+-------+| id | item_id | count |+----+---------+-------+|  1 |       1 |     1 |+----+---------+-------+1 row in set (0.00 sec)mysql> select * from my_item;+----+--------+-------+| id | name   | count |+----+--------+-------+|  1 | 手机   |    99 ||  2 | 电脑   |   100 ||  3 | 包包   |   100 |+----+--------+-------+3 rows in set (0.00 sec)

    五、删除触发器

    drop trigger 触发器名字;-- egdrop trigger after_insert_order_trigger;

    六、触发器的应用

    记录关键字 new old

    6.完善

    商品自动扣除库存

    触发器针对的是数据表中的每条记录,每行数据再操作前后都有一个对应的状态

    触发器在执行之前就将对应的数据状态获取到了:

    • 将没有操作之前的数据状态都保存到old关键字中

    • 操作后的状态都放在new

    触发器中,可以通过old和new来获取绑定表中对应的记录数据

    基本语法:

    关键字.字段名

    old和new并不是所有触发器都有

    • insert 插入前为空,没有old

    • delete 清除数据,没有new

    商品自动扣减库存:

    delimiter $$create trigger after_insert_order_trigger after insert on my_order for each rowbegin    -- 通过new关键字获取新数据的id 和数量    update my_item set count = count - new.count where id = new.item_id;end$$delimiter ;

    触发触发器:

    mysql> select * from my_order;+----+---------+-------+| id | item_id | count |+----+---------+-------+|  1 |       1 |     1 |+----+---------+-------+mysql> select * from my_item;+----+--------+-------+| id | name   | count |+----+--------+-------+|  1 | 手机   |    99 ||  2 | 电脑   |   100 ||  3 | 包包   |   100 |+----+--------+-------+insert into my_order (item_id, count) values(2, 3);mysql> select * from my_order;+----+---------+-------+| id | item_id | count |+----+---------+-------+|  1 |       1 |     1 ||  2 |       2 |     3 |+----+---------+-------+mysql> select * from my_item;+----+--------+-------+| id | name   | count |+----+--------+-------+|  1 | 手机   |    99 ||  2 | 电脑   |    97 ||  3 | 包包   |   100 |+----+--------+-------+

    2.优化

    如果库存数量没有商品订单多怎么办?

    -- 删除原有触发器drop trigger after_insert_order_trigger;-- 新增判断库存触发器delimiter $$create trigger after_insert_order_trigger after insert on my_order for each rowbegin    -- 查询库存    select count from my_item where id = new.item_id into @count;    -- 判断    if new.count > @count then        -- 中断操作,暴力抛出异常        insert into xxx values ('xxx');    end if;        -- 通过new关键字获取新数据的id 和数量    update my_item set count = count - new.count where id = new.item_id;end$$delimiter ;

    结果验证:

    mysql> insert into my_order (item_id, count) values(3, 101);ERROR 1146 (42S02): Table 'mydatabase2.xxx' doesn't existmysql> select * from my_order;+----+---------+-------+| id | item_id | count |+----+---------+-------+|  1 |       1 |     1 ||  2 |       2 |     3 |+----+---------+-------+2 rows in set (0.00 sec)mysql> select * from my_item;+----+--------+-------+| id | name   | count |+----+--------+-------+|  1 | 手机   |    99 ||  2 | 电脑   |    97 ||  3 | 包包   |   100 |+----+--------+-------+3 rows in set (0.00 sec)

    感谢各位的阅读,以上就是“MySQL数据库触发器trigger怎么使用”的内容了,经过本文的学习后,相信大家对MySQL数据库触发器trigger怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    您可能感兴趣的文档:

    --结束END--

    本文标题: MySQL数据库触发器trigger怎么使用

    本文链接: https://www.lsjlt.com/news/341210.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • MySQL数据库触发器trigger怎么使用
      这篇文章主要讲解了“MySQL数据库触发器trigger怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL数据库触发器trigger怎么使用”吧!一、基本概念触发器是一种特殊类...
      99+
      2023-07-02
    • MySQL数据库 触发器 trigger
      目录一、基本概念1、作用2、触发器的优缺点2.1、优点2.2、缺点二、创建触发器1、基本语法2、触发对象3、触发时机4、触发事件5、注意事项三、查看触发器四、触发触发器五、删除触发器六、触发器的应用1、完善2、优化一、基...
      99+
      2022-06-16
      MySQL trigger 触发器trigger
    • 数据库中触发器trigger怎么用
      这篇文章主要介绍了数据库中触发器trigger怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 实验如下:-...
      99+
      2022-10-19
    • MySQL数据库——MySQL创建触发器(CREATE TRIGGER)
      触发器是与 MySQL 数据表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性。 基本语法 在 MySQL 5.7 中,可以使用 CREATE TRIGGER 语句...
      99+
      2023-10-20
      数据库 mysql java
    • MySQL的触发器trigger怎么使用
      MySQL的触发器(trigger)可以在特定的数据库操作发生时自动执行一系列的SQL语句。触发器可以在插入、更新或删除数据时触发执...
      99+
      2023-08-11
      MySQL trigger
    • MySQL触发器trigger的使用
      Q:什么是触发器?A:  触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。触发器的特性:  1、有begin end体,begin end;之间的语句可以写的简单或者复杂 ...
      99+
      2022-10-18
    • Oracle触发器trigger怎么使用
      Oracle触发器(trigger)用于在指定的数据库操作发生时自动执行一段特定的代码,可以用于数据插入、更新或删除时执行特定的操作...
      99+
      2023-08-15
      Oracle trigger
    • 怎么创建MySQL的TRIGGER触发器
      这篇文章主要讲解了“怎么创建MySQL的TRIGGER触发器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么创建MySQL的TRIGGER触发器”吧!My...
      99+
      2022-10-18
    • mysql触发器trigger的使用案例
      这篇文章主要介绍了mysql触发器trigger的使用案例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。什么是触发器触发器是与表有关的数据库对象,在满足定义条件时触发,并执行...
      99+
      2023-06-14
    • MYSQL数据库触发器怎么用
      今天小编给大家分享一下MYSQL数据库触发器怎么用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一...
      99+
      2022-10-19
    • Java Flink窗口触发器Trigger怎么使用
      这篇文章主要介绍“Java Flink窗口触发器Trigger怎么使用”,在日常操作中,相信很多人在Java Flink窗口触发器Trigger怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对...
      99+
      2023-07-02
    • MySQL数据库触发器怎么创建
      创建MySQL数据库触发器的语法如下: CREATE TRIGGER trigger_name {BEFORE | AFTER} {...
      99+
      2023-10-26
      MySQL数据库
    • MySQL数据库触发器怎么建立
      本篇内容主要讲解“MySQL数据库触发器怎么建立”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL数据库触发器怎么建立”吧!什么是触发器?概念:触发器(trigger)是SQL serve...
      99+
      2023-06-29
    • MySQL数据库的触发器的使用
      目录使用触发器触发器创建触发器删除触发器使用触发器INSERT触发器DELETE触发器UPDATE触发器触发器的进一步介绍使用触发器 触发器 发生什么事情之后或之前,会自动执行某条语句,这就是触发器 创建触发器 创建触发...
      99+
      2022-09-29
    • MySql数据库触发器使用教程
      目录一、介绍二、操作1、表数据准备2、触发器格式3、操作三、触发器NEW和OLD的使用1、案例四、其他操作五、注意事项补充:验证触发器总结一、介绍 1、触发器是一种特殊的存储过程。触...
      99+
      2022-11-13
    • MySql数据库触发器如何使用
      这篇文章主要讲解了“MySql数据库触发器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySql数据库触发器如何使用”吧!一、介绍触发器是一种特殊的存储过程。触发器和存储过程一样,...
      99+
      2023-06-30
    • mysql触发器怎么修改数据
      要在MySQL中修改数据,可以使用触发器来实现。触发器是一种在数据库中定义的自动执行的操作,当触发器的事件发生时,会触发相应的操作。...
      99+
      2023-10-24
      mysql
    • 详解MySQL数据库之触发器
      1 引言 本文是对MySQL中触发器的总结,从触发器概念出发,结合实例对创建触发器、使用触发器、删除触发器进行介绍。 2 触发器简介 MySQL触发器和存储过程一样,都是嵌入到MySQL的一段程序。触发器是由事件...
      99+
      2022-05-20
      MySQL 触发器
    • MySQL数据库提升篇-----触发器
      day06 MySQL数据库提升篇-----触发器一、触发器概述:    触发器是什么?能有什么作用?能给我们带来什么样的操作数据库的方法这都在这里学一一的告诉大家。...
      99+
      2022-10-18
    • MySQL数据库高级(五)——触发器
      MySQL数据库高级(五)——触发器 一、触发器简介 1、触发器简介 触发器是和表关联的特殊的存储过程,可以在插入,删除或修改表中的数据时触发执行,比数据库本身标准的功能有更精细和更复杂的数据控制能力。 2...
      99+
      2022-10-18
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作