以下的文章主要向大家讲述的是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修改表字段的实际应用代码演示
【责任编辑:孙巧华 TEL:(010)68476606】

点赞 0

MySQL触发器的正确使用与案例分析的更多相关文章

  1. MySQL触发器如何正确使用

    MySQL触发器如何正确使用 2010-05-18 15:58 佚名 博客园 字号:T | T 我们今天主要向大家介绍的是MySQL触发器进行正确使用,其中包括对MySQL触发器发器的语句创建,触发时 ...

  2. MySQL 触发器结构及三个案例demo

    --你必须拥有相当大的权限才能创建触发器(CREATE TRIGGER),如果你已经是Root用户,那么就足够了.这跟SQL的标准有所不同. CREATE TRIGGER语法 CREATE TRIGG ...

  3. MySQL的索引单表优化案例分析

    建表 建立本次优化案例中所需的数据库及数据表 CREATE DATABASE db0206; USE db0206; CREATE TABLE `db0206`.`article`( `id` INT ...

  4. MySQL排序原理与MySQL5.6案例分析【转】

    本文来自:http://www.cnblogs.com/cchust/p/5304594.html,其中对于自己觉得是重点的加了标记,方便自己查阅.更多详细的说明可以看沃趣科技的文章说明. 前言    ...

  5. MySQL 5.7 GTID OOM bug案例分析 --大量压测后主从不同步

    转载自:http://www.sohu.com/a/231766385_487483 MySQL 5.7是十年内最为经典的版本,这个观点区区已经表示过很多次.然而,经典也是由不断地迭代所打造的传奇.5 ...

  6. mysql 触发器语法详解

    1.创建Mysql触发器: 语法: CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name FOR EACH ROW BE ...

  7. mysql转ElasticSearch的案例分析

    前言 最近工作中在进行一些技术优化,为了减少对数据库的压力,对于只读操作,在程序与db之间加了一层-ElasticSearch.具体实现是db与es通过bin-log进行同步,保证数据一致性,代码调用 ...

  8. MySQL全面瓦解25:构建高性能索引(案例分析篇)

    回顾一下上面几篇索引相关的文章: MySQL全面瓦解22:索引的介绍和原理分析 MySQL全面瓦解23:MySQL索引实现和使用 MySQL全面瓦解24:构建高性能索引(策略篇) 索引的十大原则 1. ...

  9. 【MySQL】排序原理与案例分析

    前言 排序是数据库中的一个基本功能,MySQL也不例外.用户通过Order by语句即能达到将指定的结果集排序的目的,其实不仅仅是Order by语句,Group by语句,Distinct语句都会隐 ...

随机推荐

  1. 剑指offer:矩形覆盖

    题目描述: 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 解题思路: 和跳台阶那道题差不多.分别以矩形的两条边长做拓 ...

  2. [2017BUAA软工]个人项目心得体会:数独

    心得体会 回顾此次个人项目,感受比较复杂,最明显的一点是--累!代码编写.单元测试.代码覆盖.性能优化,环环相扣,有种从作业发布开始就一直在赶DDL的感觉,但是很充实,也学习到和体验了很多东西.最令人 ...

  3. mysql group by分组查询

    分组的SQL语句有2个: group by 和分组聚合函数实现 partition by (oracle和postgreSQL中的语句)功能 group by + having 组合赛选数据 注意:h ...

  4. PHP TS 和 NTS 版本选择

    在PHP 开发和生产环境搭建过程中,需要安装PHP语言解析器.官方提供了2种类型的版本,线程安全(TS)版和非线程安全(NTS)版,有时后我们开发环境和实际生产的环境有所不同,因此也需要选择安装对应的 ...

  5. [转帖]常见USB种类

    随着 USB Type-C 接口被苹果推上热门话题,那么对于我们普通的消费者来说,各种 USB 接口类型我们知道多少?买一个设备回来我们是否会遇到各种接口各种线用不了的情况呢? 那么我们泪雪网新开的一 ...

  6. [转帖]华为Hi 1620 等ARM 服务器版本CPU信息.

    华为ARM服务器恐依赖党政输血续命 一旦制裁立马休克 http://www.sohu.com/a/240833070_99934330 几年前,ARM服务器被业界炒的火热,AMD.高通.Marvell ...

  7. hdu6447 YJJ's Salesman

    这个题意和数据范围一看就是离散化之后树状数组优化DP.给的"从左下方走上去才能拿到收益"的性质其实可以当成"必须从横纵坐标严格比某个点小的地方转移过来".1A了 ...

  8. Avito Cool Challenge 2018 自闭记

    A:n==2?2:1. #include<iostream> #include<cstdio> #include<cmath> #include<cstdli ...

  9. 【UOJ#80】二分图最大权匹配(KM)

    题面 UOJ 题解 模板qaq #include<iostream> #include<cstdio> #include<cstdlib> #include< ...

  10. 使用Java连接HBASE过程中问题总结

    本文是我个人在连接服务器的HBASE过程的一些问题总结. 一.用户和主机名的设置 1.1 报错:Insufficient permissions(user=Administartor) 原因:本地ho ...