• 技术文章 >数据库 >mysql教程

    一起聊聊MySQL基础之触发器和事件

    长期闲置长期闲置2022-01-20 18:07:51转载270
    本篇文章给大家带来了关于mysql中触发器和事件的相关知识,其中包括触发器使用注意事项、查看和删除事件、事件使用注意事项等等,希望对大家有帮助。

    触发器

    我们使用MySQL的过程中可能会有下边这些需求:

    也就是我们在对表中的记录做增、删、改操作前和后都可能需要让MySQL服务器自动执行一些额外的语句,这个就是所谓的触发器的应用场景。

    创建触发器

    我们看一下定义触发器的语句:

    CREATE TRIGGER 触发器名
    {BEFORE|AFTER}
    {INSERT|DELETE|UPDATE}
    ON 表名
    FOR EACH ROW
    BEGIN
        触发器内容
    END

    小贴士:

    由大括号`{}`包裹并且内部用竖线`|`分隔的语句表示必须在给定的选项中选取一个值,比如`{BEFORE|AFTER}`表示必须在`BEFORE`、`AFTER`这两个之间选取一个。

    其中{BEFORE|AFTER}表示触发器内容执行的时机,它们的含义如下:

    名称描述
    BEFORE表示在具体的语句执行之前就开始执行触发器的内容
    AFTER表示在具体的语句执行之后才开始执行触发器的内容

    {INSERT|DELETE|UPDATE}表示具体的语句,MySQL中目前只支持对INSERTDELETEUPDATE这三种类型的语句设置触发器。

    FOR EACH ROW BEGIN ... END表示对具体语句影响的每一条记录都执行我们自定义的触发器内容:

    小贴士: 如果触发器内容只包含一条语句,那也可以省略BEGN、END这两个词儿。

    因为MySQL服务器会对某条语句影响的所有记录依次调用我们自定义的触发器内容,所以针对每一条受影响的记录,我们需要一种访问该记录中的内容的方式,MySQL提供了NEWOLD两个单词来分别代表新记录和旧记录,它们在不同语句中的含义不同:

    现在我们可以正式定义一个触发器了:

    mysql> delimiter $
    mysql> CREATE TRIGGER bi_t1
        -> BEFORE INSERT ON t1
        -> FOR EACH ROW
        -> BEGIN
        ->     IF NEW.m1 < 1 THEN
        ->         SET NEW.m1 = 1;
        ->     ELSEIF NEW.m1 > 10 THEN
        ->         SET NEW.m1 = 10;
        ->     END IF;
        -> END $
    Query OK, 0 rows affected (0.02 sec)
    
    mysql> delimiter ;
    mysql>

    我们对t1表定义了一个名叫bi_t1触发器,它的意思就是在对t1表插入新记录之前,对准备插入的每一条记录都会执行BEGIN ... END之间的语句,NEW.列名表示当前待插入记录指定列的值。现在t1表中一共有4条记录:

    mysql> SELECT * FROM t1;
    +------+------+
    | m1   | n1   |
    +------+------+
    |    1 | a    |
    |    2 | b    |
    |    3 | c    |
    |    4 | d    |
    +------+------+
    4 rows in set (0.00 sec)
    
    mysql>

    我们现在执行一下插入语句并再次查看一下t1表的内容:

    mysql> INSERT INTO t1(m1, n1) VALUES(5, 'e'), (100, 'z');
    Query OK, 2 rows affected (0.00 sec)
    Records: 2  Duplicates: 0  Warnings: 0
    
    mysql> SELECT * FROM t1;
    +------+------+
    | m1   | n1   |
    +------+------+
    |    1 | a    |
    |    2 | b    |
    |    3 | c    |
    |    4 | d    |
    |    5 | e    |
    |   10 | z    |
    +------+------+
    6 rows in set (0.00 sec)
    
    mysql>

    这个INSERT语句影响的记录有两条,分别是(5, 'e')(100, 'z'),这两条记录将分别执行我们自定义的触发器内容。很显然(5, 'e')被成功的插入到了t1表中,而(100, 'z')插入到表中后却变成了(10, 'z'),这个就说明我们的bi_t1触发器生效了!

    小贴士: 我们上边定义的触发器名`bi_t1`的`bi`是`before insert`的首字母缩写,`t1`是表名。虽然对于触发器的命名并没有什么特殊的要求,但是习惯上还是建议大家把它定义我上边例子中的形式,也就是`bi_表名`、`bd_表名`、`bu_表名`、`ai_表名`、`ad_表名`、`au_表名`的形式。

    上边只是举了一个对INSERT语句设置BEFORE触发器的例子,对DELETEUPDATE操作设置BEFORE或者AFTER触发器的过程是类似的,就不赘述了。

    查看和删除触发器

    查看当前数据库中定义的所有触发器的语句:

    SHOW TRIGGERS;

    查看某个具体的触发器的定义:

    SHOW CREATE TRIGGER 触发器名;

    删除触发器:

    DROP TRIGGER 触发器名;

    这几个命令太简单了,就不举例子了啊~

    触发器使用注意事项

    事件

    有时候我们想让MySQL服务器在某个时间点或者每隔一段时间自动地执行一些语句,这时候就需要去创建一个事件

    创建事件

    创建事件的语法如下:

    CREATE EVENT 事件名
    ON SCHEDULE
    {
        AT 某个确定的时间点| 
        EVERY 期望的时间间隔 [STARTS datetime][END datetime]
    }
    DO
    BEGIN
        具体的语句
    END

    事件支持两种类型的自动执行方式:

    1. 在某个确定的时间点执行。

      比方说:

      CREATE EVENT insert_t1_event
      ON SCHEDULE
      AT '2019-09-04 15:48:54'
      DO
      BEGIN
          INSERT INTO t1(m1, n1) VALUES(6, 'f');
      END

      我们在这个事件中指定了执行时间是'2019-09-04 15:48:54',除了直接填某个时间常量,我们也可以填写一些表达式:

      CREATE EVENT insert_t1
      ON SCHEDULE
      AT DATE_ADD(NOW(), INTERVAL 2 DAY)
      DO
      BEGIN
          INSERT INTO t1(m1, n1) VALUES(6, 'f');
      END

      其中的DATE_ADD(NOW(), INTERVAL 2 DAY)表示该事件将在当前时间的两天后执行。

    2. 每隔一段时间执行一次。

      比方说:

      CREATE EVENT insert_t1
      ON SCHEDULE
      EVERY 1 HOUR
      DO
      BEGIN
          INSERT INTO t1(m1, n1) VALUES(6, 'f');
      END

      其中的EVERY 1 HOUR表示该事件将每隔1个小时执行一次。默认情况下,采用这种每隔一段时间执行一次的方式将从创建事件的事件开始,无限制的执行下去。我们也可以指定该事件开始执行时间和截止时间:

      CREATE EVENT insert_t1
      ON SCHEDULE
      EVERY 1 HOUR STARTS '2019-09-04 15:48:54' ENDS '2019-09-16 15:48:54'
      DO
      BEGIN
          INSERT INTO t1(m1, n1) VALUES(6, 'f');
      END

      如上所示,该事件将从'2019-09-04 15:48:54'开始直到'2019-09-16 15:48:54'为止,中间每隔1个小时执行一次。

      小贴士: 表示事件间隔的单位除了HOUR,还可以用YEAR、QUARTER、MONTH、DAY、HOUR、 MINUTE、WEEK、SECOND、YEAR_MONTH、DAY_HOUR、DAY_MINUTE、DAY_SECOND、HOUR_MINUTE、HOUR_SECOND、MINUTE_SECOND这些单位,根据具体需求选用我们需要的时间间隔单位。

    在创建好事件之后我们就不用管了,到了指定时间,MySQL服务器会帮我们自动执行的。

    查看和删除事件

    查看当前数据库中定义的所有事件的语句:

    SHOW EVENTS;

    查看某个具体的事件的定义:

    SHOW CREATE EVENT 事件名;

    删除事件:

    DROP EVENT 事件名;

    这几个命令太简单了,就不举例子了啊~

    事件使用注意事项

    默认情况下,MySQL服务器并不会帮助我们执行事件,除非我们使用下边的语句手动开启该功能:

    mysql> SET GLOBAL event_scheduler = ON;
    Query OK, 0 rows affected (0.00 sec)
    
    mysql>

    小贴士: event_scheduler其实是一个系统变量,它的值也可以在MySQL服务器启动的时候通过启动参数或者通过配置文件来设置event_scheduler的值。这些所谓的系统变量、启动参数、配置文件的各种东东并不是我们小白现在需要掌握的,大家忽略它们就好了~

    推荐学习:mysql视频教程

    以上就是一起聊聊MySQL基础之触发器和事件的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:CSDN,如有侵犯,请联系admin@php.cn删除
    专题推荐:mysql
    上一篇:带你搞懂MySQL字符集和比较规则 下一篇:聊聊mysql怎么开启远程访问
    千万级数据并发解决方案

    相关文章推荐

    • mysql有with as语句吗• mysql怎样查询指定条件• mysql怎样修改用户• mysql怎样修改内容• mysql怎样in查询操作排序
    1/1

    PHP中文网