【MySQL】MySQL触发器入门宝典,助力MySQL初学者打下基本功

这篇具有很好参考价值的文章主要介绍了【MySQL】MySQL触发器入门宝典,助力MySQL初学者打下基本功。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🧑‍💻作者名称:DaenCode
🎤作者简介:啥技术都喜欢捣鼓捣鼓,喜欢分享技术、经验、生活。
😎人生感悟:尝尽人生百味,方知世间冷暖。
📖所属专栏:重温MySQL


【MySQL】MySQL触发器入门宝典,助力MySQL初学者打下基本功,重温MySQL,mysql,数据库


🌟前言

在MySQL数据库中,大家都听过触发器。对于MySQL初学者而言,理解触发器的概念和应用是非常重要的。本文主要面向初学者学习MySQL触发器。

🌟触发器介绍

定义:MySQL触发器是一种数据库对象,它在指定的数据库事件(例如插入、更新或删除数据)发生时自动执行预定义的操作。触发器由两个主要组成部分组成:事件和触发操作

  • 事件:希望触发器响应的数据库操作。例如,当有数据插入到表中,或者当数据被更新或删除时,我们可以定义相应的事件。
  • 触发操作:在事件发生时触发的操作,可以是一条或多条SQL语句。触发操作可以用来实现复杂的业务逻辑、数据完整性约束和审计跟踪等需求

例子:假设我们现在要举行一个Party,当每个Party成员开门进入到Party房间时,房间里的机器就会自动说:欢迎光临Party。在这个例子中,开门是事件,而自动说欢迎词是触发操作。通过此例子我们可以定义一个触发器,当“门打开时,自动说欢迎词”。
应用

  • 电子商务网站:使用触发器来实现订单状态的更新、库存的自动调整等功能。
  • 博客系统:使用触发器记录每篇文章的浏览次数或者自动发布评论等功能。

类型

触发器类型 描述
BEFORE触发器 在事件之前执行操作,例如验证数据的有效性或进行预处理操作。
AFTER触发器 在事件之后执行操作,例如自动更新其他相关数据或记录日志。
INSTEAD OF触发器 替代原始事件的执行,例如将数据插入到视图中而不是实际表。

事件种类

触发器事件 描述
INSERT事件 在向表中插入一条记录时触发触发器。
UPDATE事件 在修改表中的一条或多条记录时触发触发器。
DELETE事件 在从表中删除一条或多条记录时触发触发器。

🌟触发器操作

以下操作中的例子都是基于以下两张表进行。

创建触发器

语法

CREATE TRIGGER trigger_name
    {BEFORE | AFTER | INSTEAD OF} {INSERT | UPDATE | DELETE}
    ON table_name
    FOR EACH ROW
    BEGIN
        -- 执行语句
    END;
  • trigger_name:触发器名称。
  • table_name:表名。
  • FOR EACH ROW:表示触发器会为每一行记录执行操作。
  • BEGIN和END之间:触发器的执行语句。

BEFORE INSERT 触发器

假设我们有一个订单表(order),需要在插入新订单之前自动生成订单号。可以创建一个 BEFORE INSERT 触发器来实现这一功能。

CREATE TABLE order (
    id INT PRIMARY KEY AUTO_INCREMENT,
    order_number VARCHAR(10),
    order_name VARCHAR(30)
);
CREATE TRIGGER generate_order_number
BEFORE INSERT ON order
FOR EACH ROW
BEGIN
    SET NEW.order_number = CONCAT('ORD', LPAD(NEW.id, 6, '0'));
END;

解释:触发器名为generate_order_number,它会在每次向订单表(order)插入新记录之前触发。FOR EACH ROW表示触发器对每一行进行操作。触发器内部的逻辑(BEGIN与END之间)是将新订单的订单号(NEW.order_number)设置为’ORD’加上新订单的ID(NEW.id),并使用LPAD函数将ID补零至6位数。

AFTER UPDATE 触发器

假设我们有一个文章表(article),需要在更新文章内容后自动记录修改时间。可以创建一个 AFTER UPDATE 触发器来实现这一功能。

CREATE TABLE article (
    id INT PRIMARY KEY AUTO_INCREMENT,
    title VARCHAR(100),
    content TEXT,
    modified_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

CREATE TRIGGER update_modified_time
AFTER UPDATE ON article
FOR EACH ROW
BEGIN
    UPDATE article SET modified_at = CURRENT_TIMESTAMP WHERE id = OLD.id;
END;

解释:触发器名为update_modified_time,它会在每次对文章表(article)进行更新操作之后触发。FOR EACH ROW表示触发器对每一行进行操作。触发器内部的逻辑是将被更新的文章(OLD.id)的修改时间(modified_at)设置为当前时间(CURRENT_TIMESTAMP)。

BEFORE DELETE 触发器

假设我们有一个用户表(user),需要在删除用户之前自动备份用户信息。可以创建一个 BEFORE DELETE 触发器来实现这一功能。

CREATE TABLE user (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(50),
    ...
);

CREATE TABLE user_backup (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(50),
    backup_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    ...
);
CREATE TRIGGER backup_user_info
BEFORE DELETE ON user
FOR EACH ROW
BEGIN
    INSERT INTO user_backup (username) VALUES (OLD.username);
END;

解释:触发器名为backup_user_info,它会在每次删除用户表(user)中的记录之前触发。FOR EACH ROW表示触发器对每一行进行操作。触发器内部的逻辑是将被删除的用户的用户名(OLD.username)插入到用户备份表(user_backup)中,并记录备份时间(backup_time)为当前时间(CURRENT_TIMESTAMP)。

删除触发器

语法DROP TRIGGER IF EXISTS trigger_name;
例子:假设我们要删除名称为calculate_total_amount的触发器。

DROP TRIGGER IF EXISTS calculate_total_amount;

查看触发器

语法SHOW TRIGGERS

SHOW TRIGGERS//查看已创建的触发器列表

🌟写在最后

最后感谢大家对于此博文的阅读,如对此内容有补充或者有疑问的地方,还望大家在评论区积极讨论。不懂得同学也可以私信留言,再一次感谢大家!


【MySQL】MySQL触发器入门宝典,助力MySQL初学者打下基本功,重温MySQL,mysql,数据库文章来源地址https://www.toymoban.com/news/detail-606400.html

到了这里,关于【MySQL】MySQL触发器入门宝典,助力MySQL初学者打下基本功的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL-触发器

    目录 🍁触发器简介 🍁创建触发器 🍃创建 BEFORE 类型触发器 🍃创建 AFTER 类型触发器 🍁删除触发器(DROP TRIGGER) 🍃删除触发器 🍁语法总结 🍃insert 🍃delete 🍃update 🦐:MySQL专栏         MySQL 数据库中触发器是一个特殊的存储过程,不同的是执行存储过程要使用 CAL

    2024年01月16日
    浏览(41)
  • 【MySQL进阶】MySQL触发器详解

    序号 系列文章 7 【MySQL基础】运算符及相关函数详解 8 【MySQL基础】MySQL多表操作详解 9 【MySQL进阶】MySQL事务详解 10 【MySQL进阶】MySQL视图详解 大家好,我是小杨!前面我已经为大家介绍了MySQL中的进阶知识-视图,那么今天我们就给大家讲解MySQL中的触发器这部分的相关内容,

    2024年02月03日
    浏览(54)
  • MySQL---存储函数、触发器

    1. 存储函数 MySQL 存储函数(自定义函数),函数一般用于计算和返回一个值,可以将经常需要使用的计算 或功能写成一个函数。 存储函数和存储过程一样,都是在数据库中定义一些 SQL 语句的集合。 存储函数与存储过程的区别: 存储函数有且只有一个返回值,而存储过程可

    2024年02月05日
    浏览(80)
  • MySQL存储过程和触发器

    存储过程和触发器是数据库中用于执行特定任务的两种重要的数据库对象。它们由SQL语句组成,被预先编译并存储在数据库中,可以通过调用来执行。以下是对存储过程和触发器的简要说明以及如何创建和使用它们: 存储过程(Stored Procedure): 定义: 存储过程是一组SQL语句

    2024年01月21日
    浏览(66)
  • MySQL 存储过程&触发器&事务

    存储过程(Stored Procedure),是为了完成特定功能的SQL语句集。 存储过程可以理解为shell脚本这类型的命令集输出工具,但是在底层,存储过程拥有更多的优点: 语言的灵活性跟功能性更强 ,在原有基础之上可以插入 控制语句、循环语句等 让SQL语句的功能更强,能够完成更

    2024年02月04日
    浏览(71)
  • MySQL数据库触发器

    查看触发器是指查看数据库中已经存在的触发器的定义、状态和语法信息等。MySQL 中查看触发器的方法包括 SHOW TRIGGERS 语句和查询 information_schema 数据库下的 triggers 数据表等。本节将详细介绍这两种查看触发器的方法。 SHOW TRIGGERS语句查看触发器信息 在 MySQL 中,可以通过 S

    2023年04月12日
    浏览(48)
  • 深入学习MYSQL-使用触发器

    触发器 每个表最多支持6个触发器,(insert,update,delete)之前和之后。 删除触发器 insert 触发器  在INSERT触发器代码内,可引用一个名为NEW的虚拟表,访问被插入的行;  在BEFORE INSERT触发器中,NEW中的值也可以被更新(允许更改被插入的值);  对于AUTO_INCREMENT列,N

    2024年02月05日
    浏览(49)
  • MySQL之视图,触发器与存储过程

    视图是一个虚拟表(非真实存在),其本质是【根据SQL语句获取动态的数据集,并为其命名】,用户使用时只需使用【名称】即可获取结果集,可以将该结果集当做表来使用。 使用视图我们可以把查询过程中的临时表摘出来,用视图去实现,这样以后再想操作该临时表的数据

    2024年02月08日
    浏览(57)
  • MySQL函数、视图、存储过程及触发器

    MySQL在我们工作中都会用到,那么我们最常接触的就是增删改查,而对于增删改查来说,我们更多的是查询。但是面试中,面试官又不会问你什么查询是怎么写的,都是问一些索引啊,事务啊, 底层结构这些东西,所以我打算分四篇去逐一的过一遍MySQL的知识点。 以下为四篇

    2023年04月09日
    浏览(60)
  • MySQL小记——存储过程、触发器、函数、视图

    目录 存储过程 procedure 语法 参数 调用存储过程 call 删除存储过程 drop 带有IF逻辑的存储过程 if then elseif else 带有循环的存储过程 while do 变量 触发器 Trigger 语法 old和new 视图 View 函数 自定义函数 内置函数 存储过程是数据库中的一个对象,存储在服务端,用来封装多条SQL语句

    2024年02月08日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包