Mysql数据库中的触发器操作

本文介绍了MySQL数据库中的触发器,它在执行DELETE、INSERT、UPDATE语句时被激活,用于增强数据完整性和业务规则。详细阐述了如何创建、查看和删除触发器,并给出了创建触发器的实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

为什么使用数据库对象触发器?

先举一个例子,在学生表中拥有字段学生名字,字段学生总数,每当添加一条关于学生记录时,学生的总数就必须同时改变。

对于这个例子,可以创建一个触发器对象,每次添加一条学生记录时,就执行一次计算学生总数的操作,这样就可以保证每次添加一条学生记录后,学生总数与学生记录数一致。

MySQL在触发如下语句时,就会自动执行所设置的操作:

DELETE 语句

INSERT语句

UPDATE语句

其他SQL语句则不会激活触发器。在具体的应用中,之所以会经常使用触发器数据库对象,是由于该对象能够加强数据库表中数据的完整性约束和业务规则等。

1.触发器创建

(1)创建一条执行语句的触发器

create trigger trigger_name

     BEFORE|AFTER trigger_EVENT

           ON TABLE_NAME FOR EACH ROW trigger_STMT

trigger_name参数表示所要创建的触发器名字;BEFORE和AFTER参数指定了触发器执行的时间,BEFORE是指在触发器事件之前执行触发器语句,AFTER表示在触发器事件之后执行触发器语句;trigger_EVENT参数表示触发事件,即触发器执行条件,包含DELETE、INSERT和UPDATE语句;FOR EACH ROW 参数表示任何一条记录上的操作满足触发事件都会触发该触发器;trigger_STMT参数表示激活触发器后被执行的语句。

CREATE TRIGGER tri_diarytime

    BEFORE INSERT

        ON t_dept FOR EACH ROW

            INSERT INTO t_diary VALUES(NULL,'t_dept',now());

#上述语句表示创建了触发器tri_diarytime,当向部门表t_dept中插入任意一条记录时,就会在插入操作之前向表t_diary中插入当前时间记录。

INSERT INTO t_dept VALUES(1,'cjgongdept','shangxi');

SELECT *

    FROM t_diary;   #校验数据库company中触发器tri_diarytime的功能。

(2)创建包含多条执行语句的触发器

DELIMITER $$

CREATE TRIGGER tri_diarytime2

     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 ;

2.查看触发器

(1) SHOW TRIGGERS \G

(2) 通过查看系统表triggers实现查看触发器

USE information_schema;

SELECT * FROM triggers \G

SELECT * FROM TRIGGERS WHERE TRIGGER_NAME='tri_diarytime2'  \G

(3)删除触发器

DROP TRIGGER trigger_name











评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值