当前位置: 移动技术网 > IT编程>数据库>Mysql > MySQL笔记之触发器的应用

MySQL笔记之触发器的应用

2017年12月12日  | 移动技术网IT编程  | 我要评论

创建触发器

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

复制代码 代码如下:

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:如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网