MySQL触发器的正确使用与案例分析

以下的文章主要向大家讲述的是MySQL触发器的实际使用详细说明与实际案例分析,同时本文也列举了一些在MySQL触发器的实际式操作中的代码,以下就是文章的详细内容介绍,望大家借鉴。

触发器案例

 

  1. mysql> select * from a; +------+------+------+ 
    | id | name | age | +------+------+------+ 
    | 1 | A1 | 10 | | 2 | A2 | 20 | +------+------+------+ 
    mysql
    > select * from b; +------+------+------+ 
    | rid | id | age | +------+------+------+ | 5 | 2 | 20 | +------+------+------+  

希望在表a的age字段更新的时候能够触发表b相应的age字段也更新:

 

如:

 

 

  1. update a set ageage=age+1 where id=2;  

 

相关的表变为:

 

  1. mysql> select * from a; +------+------+------+ 
    | id | name | age | +------+------+------+ 
    | 1 | A1 | 10 | | 2 | A2 | 21 | +------+------+------+ 
    mysql
    > select * from b; +------+------+------+ 
    | rid | id | age | +------+------+------+ | 5 | 2 | 21 | +------+------+------+ 

正确的写法

触发器代码

 

  1. CREATE TRIGGER bbs1 AFTER UPDATE ON a FOR EACH ROW update b set age=NEW.age where id=NEW.id;  

MySQL触发器

 

触发器的概念:“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。

当一个新整数值增加到数据库域中时,自动更新运行的总数的代码段是一个触发器。自动记录对一个特殊数据库表格所作更改的SQL命令块也是一个触发器实例。

触发器是MySQL 5.x的新功能,随着5.x代码树新版本的出现,这一功能也逐渐得到改善。在本文中,我将简单介绍如何定义并使用触发器,查看触发器状态,并如何在使用完毕后删除触发器。我还将为你展示一个触发器在现实世界中的应用实例,并检验它对数据库记录的改变。

 

例子

 

通过简单(虽然是人为的)实例来说明是了解MySQL触发器应用的***办法。首先我们建立两个单域的表格。一个表格中为姓名列表(表格名:data),另一个表格中是所插入字符的字符数(表格名:chars)。我希望在data表格中定义一个触发器,每次在其中插入一个新姓名时,chars表格中运行的总数就会根据新插入记录的字符数目进行自动更新。

 

 

 

  1. mysql> CREATE TABLE data (name VARCHAR(255)); 
    Query OK, 0 rows affected (0.09 sec) mysql
    > CREATE TABLE chars (count INT(10)); 
    Query OK, 0 rows affected (0.07 sec) mysql
    > INSERT INTO chars (count) VALUES (0); 
    Query OK, 1 row affected (0.00 sec) mysql
    > CREATE TRIGGER t1 
    AFTER INSERT ON data FOR EACH ROW UPDATE chars SET 
    countcount = count + CHAR_LENGTH(NEW.name); Query OK, 0 rows affected (0.01 sec)  

     

 

理解上面代码的关键在于CREATE TRIGGER命令,它被用来定义一个新触发器。这个命令建立一个新触发器,假定的名称为t1,每次有一个新记录插入到data表格中时,t1就被激活。

 

在这个触发器中有两个重要的子句:

 

AFTER INSERT子句表明触发器在新记录插入data表格后激活。

 

UPDATE chars SET count = count + CHAR_LENGTH(NEW.name)子句表示触发器激活后执行的SQL命令。在本例中,该命令表明用新插入的data.name域的字符数来更新 chars.count栏。这一信息可通过内置的MySQL函数CHAR_LENGTH()获得。

 

放在源表格域名前面的NEW关键字也值得注意。这个关键字表明触发器应考虑域的new值(也就是说,刚被插入到域中的值)。MySQL还支持相应的OLD前缀,可用它来指域以前的值。

 

你可以通过调用SHOW TRIGGER命令来检查触发器是否被激活。

 

 

 

  1. mysql> SHOW TRIGGERS; *************************** 
    1. row *************************** 
    ?Trigger: t1 ?Event: INSERT ?Table: data Statement: 
    UPDATE chars SET 
    countcount = count + CHAR_LENGTH(NEW.name) 
    Timing: AFTER ?Created: NULL ql_mode: 1 row in set (0.01 sec)  

 

激活触发器后,开始对它进行测试。试着在data表格中插入几个记录:

 

 

 

  1. mysql> INSERT INTO data (name) VALUES ('Sue'), ('Jane'); 
    Query OK, 2 rows affected (0.00 sec) Records: 2?Duplicates: 0?Warnings: 0 

 

然后检查chars表格看MySQL触发器是否完成它该完成的任务:

 

 

  1. mysql> SELECT * FROM chars; +-------+ 
    | count | +-------+ | 7| +-------+ 1 row in set (0.00 sec) 

 

如你所见,data表格中的INSERT命令激活触发器,它计算插入记录的字符数,并将结果存储在chars表格中。如果你往data表格中增加另外的记录,chars.count值也会相应增加。

触发器应用完毕后,可有DROP TRIGGER命令轻松删除它。

 

 

 

  1. mysql> DROP TRIGGER t1; Query OK, 0 rows affected (0.00 sec) 

 

注意:理想情况下,你还需要一个倒转触发器,每当一个记录从源表格中删除时,它从字符总数中减去记录的字符数。这很容易做到,你可以把它当作练习来完成。提示:应用BEFORE DELETE ON子句是其中一种方法。

自写(已测试)

 

 

  1. mysql> create trigger t2 before delete on 
    data for each row update chars set 
    countcount=count-char_length(old.name); 
    Query OK, 0 rows affected (0.03 sec) 

 

现在,我想建立一个审计记录来追踪对这个表格所做的改变。这个记录将反映表格的每项改变,并向用户说明由谁做出改变以及改变的时间。我需要建立一个新表格来存储这一信息(表格名:audit),如下所示。(列表C)

列表C

 

 

 

  1. mysql> CREATE TABLE audit (id INT(7), balance FLOAT, 
    user VARCHAR(50) NOT NULL, time TIMESTAMP NOT NULL); 
    Query OK, 0 rows affected (0.09 sec) 
    mysql
    > create table accounts(id int(7),label VARCHAR(45),balance float); 

 

接下来,我将在accounts表格中定义一个MySQL触发器。(列表D)

列表D

 

 

 

  1. mysql> CREATE TRIGGER t3 AFTER UPDATE ON accounts 
    FOR EACH ROW INSERT INTO audit (id, balance, user, time) 
    VALUES (OLD.id, NEW.balance, CURRENT_USER(), NOW()); 
    Query OK, 0 rows affected (0.04 sec) 

 

如果你已经走到这一步,就很容易理解。accounts表格每经历一次UPDATE,触发器插入(INSERT)对应记录的id、新的余额、当前时间和登录audit表格的用户的名称。

实现中的例子:用触发器审计记录

既然你了解了触发器的基本原理,让我们来看一个稍稍复杂的例子。我们常用触发器来建立一个自动“审计记录”,以记录各种用户对数据库的更改。为了解审计记录的实际应用,请看下面的表格(表格名:accounts),它列出了一个用户的三个银行账户余额。(表A)

 

表A

 

 

 

  1. mysql> SELECT * FROM accounts; +----+------------+---------+ 
    | id | label| balance | +----+------------+---------+ 
    |1 | Savings #1 |500 | |2 | Current #1 |2000 | |3 | 
    Current #2 |3500 | +----+------------+---------+ 3 rows in set (0.00 sec) 

 

然后,检查触发器是否被激活:

 

 

  1. mysql> SHOW TRIGGERS ; *************************** 
    1. row *************************** ?Trigger: t1 ?Event: 
    UPDATE ?Table: accounts Statement: INSERT INTO audit (id, balance, user, time) 
    VALUES (OLD.id, NEW.balance, CURRENT_USER(), NOW()) Timing: AFTER ?Created: NULL Sql_mode: 1 row in set (0.01 sec) 

 

再来看***的结果(列表E):

列表E

 

 

 

  1. mysql> UPDATE accounts SET balance = 500 WHERE id = 
    1; Query OK, 1 row affected (0.00 sec) Rows matched: 
    1?Changed: 1?Warnings: 0 mysql
    > UPDATE accounts SET 
    balance = 900 WHERE id = 3; Query OK, 1 row affected 
    (0.01 sec) Rows matched: 1?Changed: 1?Warnings: 0 mysql
    > 
    UPDATE accounts SET 
    balance = 1900 WHERE id = 1; Query OK, 
    1 row affected (0.00 sec) Rows matched: 1?Changed: 1?Warnings: 0  

 

注意,对accounts表格所作的改变已被记录到audit表格中,将来如果出现问题,我们可以方便地从中进行恢复。

 

 

  1. mysql> SELECT * FROM audit; +------+---------+----------------+---------------------+ 
    | id| balance | user| time| +------+---------+----------------+---------------------+ 
    |1 |500 | root@localhost | 2006-04-22 12:52:15 | |3 |900 | root@localhost | 2006-04-22 12:53:15 
    | |1 |1900 | root@localhost | 2006-04-22 12:53:23 | +------+---------+----------------+---------------------+ 3 rows in set (0.00 sec)  

 

如上面的例子所示,MySQL触发器是一个强大的新功能,它大大增强了RDBMS的自动化程度。自己去试验,练习吧!

【编辑推荐】

  1. MySQLunion 语法代码演示
  2. 导致MySQL Alter Table函数信息泄露的原因
  3. MySQL alter 语句的实际操作
  4. MySQL查询优化的5个好用方法
  5. MySQL修改表字段的实际应用代码演示

 

 

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/273344.html<

(0)
运维的头像运维
上一篇2025-05-09 05:40
下一篇 2025-05-09 05:41

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注