mysql之触发器详解_学习笔记之MySQL触发器详解

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

创建触发器

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

CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件

ON 表名 FOR EACH ROW 执行语句其中,触发器名参数指要创建的触发器的名字

1、创建MySQL触发器:

语法:

代码如下

CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name

FOR EACH ROW

BEGIN

trigger_stmt

END;

CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name

FOR EACH ROW

BEGIN

trigger_stmt

END;

例子

代码如下

CREATE TRIGGER SetUserHome after insert ON users

FOR EACH ROW

BEGIN

update `users` set homeLocationX = 128,

homeLocationY=128, homeLocationZ=30

where uuid = NEW.uuid

END

以上的例子是错误的, 让本表进行触发时进行更新会让程序进入死循环。

系统会报这样的错误:it is already used by statement which invoked this stored function/trigger.

应该改成以下语句:

代码如下

CREATE TRIGGER SetUserHome before insert ON users

FOR EACH ROW

BEGIN

set New.homeLocationX = 128;

set New.homeLocationY = 128;

set New.homeLocationZ=30;

END

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 TRIGGERSG;

*************************** 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.triggersG

*************************** 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: worktips

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

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

删除触发器

mysql> DROP TRIGGER trig1;

Query OK, 0 rows affected (0.04 sec)删除触发器之后最好使用上面的方法查看一遍

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

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

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值