MySQL数据库的触发器的使用

 更新时间:2022年09月29日 09:39:57   作者:阿柠xn​​​​​​​  
这篇文章主要介绍了MySQL数据库的触发器的使用,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下

使用触发器

触发器

发生什么事情之后或之前,会自动执行某条语句,这就是触发器

创建触发器

创建触发器要给出的4条关键信息:

  • 1.唯一的触发器名
  • 2.触发器关联的表
  • 3.触发器应该响应的活动(DELETE,INSERT or UPDATE)
  • 4.触发器何时执行(处理之前or之后)

CREATE TRIGGER语句创建触发器

CREATE TRIGGER newproduct AFTER INSERT ON products
FOR EACH ROW
SELECT 'Product added';

FOR EACH ROW 代码对每个插入行执行。

删除触发器

DROP TRIGGER newproduct;

使用触发器

INSERT触发器

INSERT触发器在INSERT语句执行之前或之后执行。需要知道一下几点:

  • 在INSERT触发器的代码内,可引用一个名为NEW 的虚拟表,访问被插入的行。
  • 在BEFORE INSERT触发器中,NEW中 的值也可以被更新(允许更改被插入的值)
  • 对于AUTO_INCREMENT列,NEW 在INSERT执行之前包含0,在INSERT执行之后包含新的自动生成值。
CREATE TEIGGER neworder  AFTER INSERT ON orders
FOR EACH ROW SELECT NEW.order_num;

这个触发器讲了咋个事情呢?你不要觉得云里雾里的,我们知道这个INSERT是不会显示什么信息出来的,所以我们加一个 AFTER INSERT

就是你只要一插入,我们就读出来这个订单号显示出来。就是这么一个功能,你不要想的太复杂了。所以你只能AFTER昂,BEFORE你能读出来个啥。

DELETE触发器

你也需要知道几点:

  • 在DELETE触发器的代码中,你可以引用一个名为OLD的虚拟表,访问被删除的行。
  • OLD中的值全都是只读,不能更新。

例:演示使用OLD保存将要删除的行到一个存档表中。

CREATE TRIGGER deleteorder BEFORE DELETE ON oreders
FOR EACH ROW
BEGIN 
    INSERT INTO archive_orders(order_num,order_date,cust_id)
    VALUES(OLD.order_num,OLD.order_date,OLD.cust_id);
END;

UPDATE触发器

注意几点:

  • 在UPDATE触发器代码中,你可以引用一个OLD的虚拟表访问以前的值,引用一个名为NEW的虚拟表访问更新的值。
  • 在BEFORE UPDATE触发器中,NEW中的值可能也被更新
  • OLD中的全是只读的。

例:保证州名缩写总是大写

CREATE TRIGGER updatevendor BEFORE UPDATE ON vendors
FOR EACH ROW SET NEW.vend_state = Upper(New.vend_state); 

⭕️这个例子我想说一下,它这个的话就意味着我们对这个NEW的改变是会影响到实际表中的。这点应该注意到。

触发器的进一步介绍

MySQL触发器是不支持CALL语句的,这是十分遗憾的,所需的存储过程的代码需要复制到触发器内。

到此这篇关于MySQL数据库的触发器的使用的文章就介绍到这了,更多相关MySQL触发器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何更改MySQL数据库的编码为utf8mb4

    如何更改MySQL数据库的编码为utf8mb4

    utf8mb4编码是utf8编码的超集,兼容utf8,并且能存储4字节的表情字符。 这篇文章给大家介绍了更改MySQL数据库的编码为utf8mb4的相关知识,感兴趣的朋友一起看看吧
    2020-02-02
  • MySql中的常用参数查询

    MySql中的常用参数查询

    这篇文章主要介绍了MySql中的常用参数查询,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • MySQL SQL 语法参考

    MySQL SQL 语法参考

    MySQL SQL 语法参考...
    2006-12-12
  • 30种SQL语句优化的方法汇总

    30种SQL语句优化的方法汇总

    这篇文章从30个方面,分享了sql优化的一些小技巧,希望对你有所帮助,需要的朋友可以参考下
    2022-10-10
  • mysql 判断记录是否存在方法比较

    mysql 判断记录是否存在方法比较

    把数据写入到数据库的时,常常会碰到先要检测要插入的记录是否存在,然后决定是否要写入。
    2011-08-08
  • mysql导入csv的4种报错的解决方法

    mysql导入csv的4种报错的解决方法

    这篇文章主要介绍了mysql导入csv的4种报错的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 关于mysql 的时间类型选择

    关于mysql 的时间类型选择

    本篇文章是对mysql中的时间类型选择进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • MySQL 普通索引和唯一索引的区别详解

    MySQL 普通索引和唯一索引的区别详解

    这篇文章主要介绍了MySQL 普通索引和唯一索引的区别详解,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03
  • MySQL磁盘碎片整理实例演示

    MySQL磁盘碎片整理实例演示

    这篇文章主要给大家介绍了关于MySQL磁盘碎片整理的相关资料,为什么数据库会产生碎片,以及如何清理磁盘碎片,还有一些清理磁盘碎片的注意事项,需要的朋友可以参考下
    2022-04-04
  • MySQL主从复制基于binlog与GTID详解

    MySQL主从复制基于binlog与GTID详解

    本文介绍了基于binlog和GTID的MySQL主从复制搭建步骤,包括准备环境、创建授权账户、配置主从库等,通过主从复制,可以实现数据的高可用、负载均衡和灾难恢复,首先,确保环境一致性,然后在数据库中创建具有复制权限的账户
    2024-10-10

最新评论