MySQL从入门到精通_6触发器的操作

6-触发器的操作

    在MySQL数据库中,数据库对象表时存储和操作数据的逻辑结构,而触发器则用来实现由一些表事件触发的某个操作,时与数据库对象表关联最紧密的数据库对象之一,在数据库系统中,当执行表事件时,则会激活触发器,从而执行其包含的操作。

6-1为什么使用触发器

    触发器(TRIGGER)是MySQL的数据库对象之一,该对象与编程语言的中函数非常类似,都需要声明、执行等。但是触发器的执行不是由程序调用,也不是由手工启动,而是由时间来触发、激活从而实现

    那么为什么要使用数据对象触发器呢?在具体开发项目是,经常会遇到如下实例:
  • 在学生表中拥有字段学生名字,字段学生总数,每当添加一条关于学生的记录时,学生的总数必须同时改变。
  • 在顾客信息表中拥有字段顾客名称,字段顾客电话和字段顾客的地址缩写,每当添加一条关于顾客的记录事,都需要检查电话号码格式是否正确,顾客地址缩写是否正确。

上述实例虽然所需要实现的业务逻辑不同,但是他们也有共同之处,即都需要在表发生变化时,自动进行一些处理。这是就可以使用触发器处理数据库对象,列如,第一个实例,可以创建一个触发器对象,每次添加一条学生记录时,就执行一次计算学生总数的操作,这样就可以保证每次添加一条学生记录后,学生总数与学生记录数一致。

6-2创建触发器

6-2-1 创建有一条执行语句的触发器

 CREATE TRIGGER trigger_name
     BEFORE|AFTER trigger_EVENT
         ON TABLE_name FOR EACH ROW trigger_STMT

在上述语句中,trigger_name参数表示所要创建的触发器名字,再具体创建触发器是,触发器标识符不能与已经存在的触发器重复。除了上述要求外,建议触发器命名(标识符)为trigger_xxx或者tri_xxx;BEFORE和AFTER参数指定了触发器执行的时间,其中前者是指在触发器时间之前执行触发器语句,后者是指在触发器事件之后执行触发器语句;trigger_EVENT参数表示触发事件,即触发器执行条件,包含DELETE、UPDATE、INSERT语句;TABLE_NAME参数表示触发事件操作表的名字;FOR EACH ROW 参数表示任何一条记录上的操作满足触发事件都会触发该触发器;trigger_STMT参数表示激活触发器后被执行的语句。

6-2-2 创建包含多条执行语句的触发器

 CREATE TRIGGER trigger_name
     BEFORE|AFTER trigger_EVENT
         ON TABLE_NAME FOR EACH ROW
             BEGIN
             trigger_STMT
             END

在上述语句,比“只有一条执行语句的触发器”语法多出来了关键字BEGIN和END,在这两个关键字之间所要执行的多个执行语句的内容,执行语句之间用分号隔开。

在MySQL软件中,一般情况下用“;”符号作为语句的结束符号,可以在创建触发器时,需要用到“;”符号作为执行语句的结束符号。为了解决该问题,可以使用关键字DELIMITER语句,例如“DELIMITER

”。

实例:
在数据company中存在两个表对象:部门表(t_dept)和日记表(t_diary),创建触发器实现当向部门表插入是,就会在插入之后向日记表中插入两条记录

 DELIMITER $$
 CREATE TRIGGER tri_diraytime2
	 AFTER INSERT
		 ON t_dept FOR EACH ROW
			 BEGIN
				 INSERT INTO t_diary VALUES(NULL,t_dept,NOW());
 				 INSERT INTO t_diary VALUES(NULL,t_dept,NOW());
 			END
 			$$
    DELIMITER;

代码说明:在上述语句中,首先通过“DELIMITER $$”语句设置结束符号为“$ $”,然后在关键字BEGIN和END之间编写了执行语句列表,最后通过“DELIMITER;”语句将结束符号还原成默认结束符号“;”。

6-3 查看触发器

6-3-1通过 SHOW TRIGGERS 语句查看触发器

当创建触发器时,除了会经常发生”ERROR 1359 (HY000): Trigger already exists”错误外,还有发生”ERROR 1234(42000): This version of MySQL doesn’t yet support ‘muliple triggers with thr same action and event for on table’”因为该触发器已经存在外,还以为在MySQL软件中,MySQL对于具有相同的触发程序动作时间和事件的给定表,不能有两个触发器。因此在创建触发器之前,需要查看MySQL软件中是否已经存在该标识符的触发器和触发器的相关事件。

SHOW TRIGGERS

这里写图片描述

通过执行SQL语句结果可以发现,执行完“SHOW TRIGGERS” 语句后,会显示一个列表,在该列表中,会显示出所有触发器的信息。其中Trigger参数表示触发器的名称,Event参数表示触发器的激活事件,Table参数表示触发器对象触发时间所操作的表,Statement参数表示触发器激活时所执行的语句,Timing参数表示触发器所执行的时间

6-4 删除触发器

6-4-1 通过DROP TRIGGER 语句删除触发器

DROP TIGGER trigger_name

在上述语句中,trigger_name参数表示所要删除的触发器名称。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值