服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|

服务器之家 - 数据库 - Mysql - MySQL笔记之触发器的应用

MySQL笔记之触发器的应用

2019-12-24 14:33MYSQL教程网 Mysql

触发器是由事件来触发某个操作,这些事件包括INSERT语句,UPDATE语句和DELETE语句

创建触发器

创建只有一个执行语句的触发器

复制代码代码如下:

CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件
ON 表名 FOR EACH ROW 执行语句


其中,触发器名参数指要创建的触发器的名字

 

BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后

FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器

复制代码代码如下:

mysql> CREATE TRIGGER trig1 AFTER INSERT
    -> ON work FOR EACH ROW
    -> INSERT INTO time VALUES(NOW());
Query OK, 0 rows affected (0.09 sec)


上面创建了一个名为trig1的触发器,一旦在work中有插入动作,就会自动往time表里插入当前时间

 


创建有多个执行语句的触发器

复制代码代码如下:

CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件
ON 表名 FOR EACH ROW
BEGIN
    执行语句列表
END


其中,BEGIN与END之间的执行语句列表参数表示需要执行的多个语句,不同语句用分号隔开

 

tips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突

     为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||

     当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;

复制代码代码如下:


mysql> DELIMITER ||
mysql> CREATE TRIGGER trig2 BEFORE DELETE
    -> ON work FOR EACH ROW
    -> BEGIN
    -> INSERT INTO time VALUES(NOW());
    -> INSERT INTO time VALUES(NOW());
    -> END
    -> ||
Query OK, 0 rows affected (0.06 sec)

 

mysql> DELIMITER ;


上面的语句中,开头将结束符号定义为||,中间定义一个触发器,一旦有满足条件的删除操作

 

就会执行BEGIN和END中的语句,接着使用||结束

最后使用DELIMITER ; 将结束符号还原


查看触发器
SHOW TRIGGERS语句查看触发器信息

复制代码代码如下:

mysql> SHOW TRIGGERS\G;
*************************** 1. row ***************************
             Trigger: trig1
               Event: INSERT
               Table: work
           Statement: INSERT INTO time VALUES(NOW())
              Timing: AFTER
             Created: NULL
            sql_mode: 
             Definer: root@localhost
character_set_client: utf8
collation_connection: utf8_general_ci
  Database Collation: latin1_swedish_ci


结果会显示所有触发器的基本信息

 

tips:SHOW TRIGGERS语句无法查询指定的触发器


在triggers表中查看触发器信息

复制代码代码如下:

mysql> SELECT * FROM information_schema.triggers\G
*************************** 1. row ***************************
           TRIGGER_CATALOG: def
            TRIGGER_SCHEMA: person
              TRIGGER_NAME: trig1
        EVENT_MANIPULATION: INSERT
      EVENT_OBJECT_CATALOG: def
       EVENT_OBJECT_SCHEMA: person
        EVENT_OBJECT_TABLE: work
              ACTION_ORDER: 0
          ACTION_CONDITION: NULL
          ACTION_STATEMENT: INSERT INTO time VALUES(NOW())


结果显示了所有触发器的详细信息,同时,该方法可以查询制定触发器的详细信息

复制代码代码如下:

mysql> SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME='trig1'\G
*************************** 1. row ***************************
           TRIGGER_CATALOG: def
            TRIGGER_SCHEMA: person
              TRIGGER_NAME: trig1
        EVENT_MANIPULATION: INSERT
      EVENT_OBJECT_CATALOG: def
       EVENT_OBJECT_SCHEMA: person
        EVENT_OBJECT_TABLE: work


tips:所有触发器信息都存储在information_schema数据库下的triggers表中

 

     可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询


删除触发器

复制代码代码如下:

mysql> DROP TRIGGER trig1;
Query OK, 0 rows affected (0.04 sec)


删除触发器之后最好使用上面的方法查看一遍

 

同时,也可以使用database.trig来指定某个数据库中的触发器

tips:如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作

延伸 · 阅读

精彩推荐
  • Mysqlphpmyadmin出现#2003服务器无响应解决方法小结

    phpmyadmin出现#2003服务器无响应解决方法小结

    出现登陆phpmyadmin出现 #2003 - 服务器没有响应最先想到的是你的mysql服务器是不是停止了检查一下,如果是mysql服务器停止服务了重启就可以解决问题了 ...

    MYSQL教程网3752019-12-02
  • Mysqlmysql服务启动不了解决方案

    mysql服务启动不了解决方案

    最近在Windows 2003上的MySQL出现过多次正常运行时无法连接数据库故障,现象是无法连接数据库,也无法停止MySQL或重启MYSQL,由于每次都是草草尝试各种方法搞...

    MYSQL教程网5022019-12-10
  • MysqlMYSQL WHERE语句优化

    MYSQL WHERE语句优化

    where优化主要是在SELECT中,因为他们最主要是在那里使用,但是同样的优化也可被用于DELETE和UPDATE语句。 ...

    mysql教程网5062019-10-26
  • Mysqlmysql 模糊搜索的方法介绍

    mysql 模糊搜索的方法介绍

    本文将提供两种方法,第一种最土的方法:使用like语句第二种用全文索引,接下来将为你详细介绍 ...

    MYSQL教程网2622019-12-10
  • Mysqlmysql sql_mode="" 的作用说明

    mysql sql_mode="" 的作用说明

    在看discuz源码时看到了sql_mode="",不知道是干嘛的,猜想是设置模式,但是不清楚是什么模式,于是从网上搜了下,sql_mode="" 的作用 ...

    MYSQL教程网3482019-11-23
  • Mysql解决mysql ERROR 1017:Can't find file: '/xxx.frm' 错误

    解决mysql ERROR 1017:Can't find file: '/xxx.frm' 错误

    如果重启服务器前没有关闭mysql,MySql的MyiSAM表很有可能会出现 ERROR #1017 :Can't find file: '/xxx.frm' 的错误 ...

    MYSQL教程网1542019-11-21
  • Mysql有关mysql优化的一些东东整理

    有关mysql优化的一些东东整理

    有关mysql优化的一些东东,自己整理的,网上搜集的,供朋友们学习参考吧 ...

    MYSQL教程网1932019-12-17
  • MysqlMySQL8新特性:持久化全局变量的修改方法

    MySQL8新特性:持久化全局变量的修改方法

    这篇文章主要给大家介绍了关于MySQL 8新特性:持久化全局变量的修改的相关内容,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参...

    iVictor4652019-07-02