博客
关于我
MYSQL:基础——触发器
阅读量:802 次
发布时间:2023-02-11

本文共 1842 字,大约阅读时间需要 6 分钟。

MYSQL基础——触发器

引入触发器

在数据库设计中,某些操作需要在特定事件发生时自动执行。例如,当用户订购产品时,从库存中减去订购数量;或者删除数据时,自动将其备份到存档表。这种自动执行的功能可以通过触发器实现。

触发器是MySQL响应以下任意语句而自动执行的一条MySQL语句或一组语句,前提是触发器关联到特定表。支持触发器的操作包括:

  • DELETE
  • INSERT
  • UPDATE

其他语句如SELECT、CREATE等不支持触发器。


创建触发器

触发器可以通过 CREATE TRIGGER 语句创建。伪代码示例如下:

CREATE TRIGGER newType AFTER INSERT ON ms_articletype FOR EACH ROW SELECT 'Product Added';

创建触发器需要提供以下信息:

  • 触发器名称:例如 newType
  • 关联的表:例如 ms_articletype
  • 支持的操作:例如 DELETEINSERTUPDATE
  • 触发时机:例如 AFTER INSERTBEFORE UPDATE

  • 删除触发器

    触发器不支持直接更新或覆盖,因此要修改触发器必须先删除它,再重新创建。删除触发器的语法如下:

    DROP TRIGGER newType;

    使用触发器

    INSERT触发器

    INSERT 语句执行前或后,触发器会自动执行。以下是使用 INSERT 触发器时需注意的事项:

  • 虚拟表的引用:在触发器代码中,可以引用名为 NEW 的虚拟表访问被插入的行。
  • 更新被插入值:在 BEFORE INSERT 触发器中,可以通过 NEW 修改被插入的数据。
  • 自增字段处理NEWINSERT 执行前包含 0,执行后包含新生成的自增值。
  • 示例

    在插入新类型时,触发器会自动记录日志。

    CREATE TRIGGER logTypeInsert AFTER INSERT ON ms_articletype FOR EACH ROW INSERT INTO log_table (type, datetime) VALUES (NEW.type, CURRENT_TIMESTAMP);

    DELETE触发器

    DELETE 语句执行时,触发器会自动执行。以下是使用 DELETE 触发器时需注意的事项:

  • 虚拟表的引用:在触发器代码中,可以引用名为 OLD 的虚拟表访问被删除的行。
  • 只读访问OLD 表中的数据不可修改,只能读取。
  • 示例

    当删除订单时,触发器会更新相关销售记录。

    CREATE TRIGGER updateSales DELETE ON ms_order FOR EACH ROW UPDATE ms_sale SET total = total + (OLD.amount - NEW.amount) WHERE order_id = OLD.order_id;

    UPDATE触发器

    UPDATE 语句执行时,触发器会自动执行。以下是使用 UPDATE 触发器时需注意的事项:

  • 虚拟表的引用:在触发器代码中,可以同时引用 OLDNEW 虚拟表。
  • 只读访问OLD 表中的值不可修改。
  • 更新操作:在 BEFORE UPDATE 触发器中,可以修改 NEW 中的值,影响 UPDATE 语句的执行结果。
  • 示例

    当更新商品库存时,触发器会更新相关订单的数量。

    CREATE TRIGGER updateInventory BEFORE UPDATE ON ms_goods FOR EACH ROW IF NEW.stock < OLD.stock THEN UPDATE ms_order SET stock = stock + (OLD.stock - NEW.stock) WHERE product_id = OLD.product_id;

    退货实例

    以下是一个实际应用场景的触发器示例:

    CREATE TRIGGER updateGoods AFTER UPDATE ON ms_sale FOR EACH ROW UPDATE ms_order SET or_number = or_number + (OLD.sale_number - NEW.sale_number) WHERE or_id = OLD.sale_or_id;

    当销售订单数量被更新时,触发器会根据差异自动更新相关订单的数量。

    转载地址:http://wibfk.baihongyu.com/

    你可能感兴趣的文章
    MySQL底层概述—6.索引原理
    查看>>
    MySQL底层概述—7.优化原则及慢查询
    查看>>
    MySQL底层概述—8.JOIN排序索引优化
    查看>>
    MySQL底层概述—9.ACID与事务
    查看>>
    Mysql建立中英文全文索引(mysql5.7以上)
    查看>>
    mysql建立索引的几大原则
    查看>>
    Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
    查看>>
    mysql开启bin-log日志,用于canal同步
    查看>>
    MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
    查看>>
    MySQL异步操作在C++中的应用
    查看>>
    MySQL引擎讲解
    查看>>
    Mysql当前列的值等于上一行的值累加前一列的值
    查看>>
    MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
    查看>>
    MySQL必知必会(组合Where子句,Not和In操作符)
    查看>>
    MySQL必知必会总结笔记
    查看>>
    MySQL快速入门
    查看>>
    MySQL快速入门——库的操作
    查看>>
    mysql快速复制一张表的内容,并添加新内容到另一张表中
    查看>>
    mysql快速查询表的结构和注释,字段等信息
    查看>>
    mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
    查看>>