详细解读MySQL的触发器trigger
作者:九月木码 发布时间:2024-01-24 18:24:24
什么是触发器
MySQL的触发器(trigger)和存储过程一样,都是嵌入到MySQL中的一段程序。触发器是由事件来触发某个操作,这些事件包括INSERT、UPDATE和DELETE语句。如果定义了触发程序,当数据库执行这些语句的时候就会激发触发器执行相应的操作,触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。
创建触发器
触发器是个特殊的存储过程,不同的是,执行存储过程要使用CALL语句来调用,而触发器的执行不需要使用CALL语句调用,也不需要手工启动,只要当一个预定义的事件发生的时候,就会被MySQL自动调用。比如对student表进行操作(INSERT、DELETE或UPDATE)时就会激活它执行。
触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于满足复杂的业务规则或要求。可以创建只有一条语句的触发器,不过一般都是有多个执行语句的触发器用得比较多,即使单条语句的触发器,也可以使用多条语句的触发器的写法来写,看下有多个执行语句的触发器的基本写法:
CREATE TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
解释一下:
1、trigger_name标识触发器名称,用户自行指定
2、trigger_time标识触发时机,可以指定为before或after
3、trigger_event标识触发事件,包括INSERT、UPDATE和DELETE
4、tbl_name标识建立触发器的表名,即在哪张表上建立触发器
5、trigger_stmt是触发器程序体,触发器程序可以使用begin和end作为开始和结束,中间包含多条语句
触发器程序可以使用begin和end作为开始和结束,中间包含多条语句。举个例子,还是以前的学生表:
create table student
(
studentId int primary key auto_increment not null,
studentName varchar(10) not null,
studentAge int,
studentPhone varchar(15)
)
给学生表的studentName、studentAge、studentPhone三个字段都创建一个触发器表:
create table triggerstudentname
(
t_studentName VARCHAR(10)
);
create table triggerstudentAge
(
t_studentAge int
);
create table triggerstudentPhone
(
t_studentPhone VARCHAR(15)
);
创建一个触发器,每次插入一条数据之后分别往三张表插字段:
CREATE TRIGGER trigger_student AFTER INSERT ON student
FOR EACH ROW
BEGIN
INSERT INTO triggerstudentname values(NEW.studentName);
INSERT INTO triggerstudentAge values(NEW.studentAge);
INSERT INTO triggerstudentPhone values(NEW.studentPhone);
END
插入三条数据:
insert into student values(null,'Jack', '11', '55555555');
insert into student values(null,'Dicky', '14', '66666666');
insert into student values(null,'Coco', '19', '77777777');
commit;
看一下三张表的情况:
没什么问题,执行结果显示,在向student表插入数据的同时,triggerstudentname、triggerstudentAge和triggerstudentPhone三张表里面的数据都发生了变化,INSERT动作触发了触发器。
查看触发器
查看触发器是指查看数据库中已存在的触发器的定义、状态和语法信息等。可以通过命令来查看已经创建的触发器,有两种方式可以查看触发器,一一讲解。
1、SHOW TRIGGERS语句查看触发器
通过SHOW TRIGGERS查看触发器的语句如下:
SHOW TRIGGERS;
用这个命令来查看一下触发器:
有一部分没截取完整,解释一下主要部分的含义:
(1)Trigger表示触发器的名称,这里有两个触发器分别是tri_student和trigger_student
(2)Event表示激活触发器的事件,这里的两个触发事件为插入操作INSERT
(3)Table表示激活触发器的操作对象表,这里都为student表
(4)Statement表示激活触发器之后执行的语句
(5)Timing表示触发器触发的时间,分别为插入操作之前(BEFORE)和插入操作之后(AFTER)
2、在triggers表中查看触发器信息
SHOW TRIGGERS语句查看当前创建的所有触发器信息,这在触发器较少的情况下,使用该语句会很方便,如果要查看特定的触发器信息,可以直接从infomation_schema数据库中的triggers表中查找,通过SELECT命令查看,基本语法为:
SELECT * FROM INFORMATION_SCHEMA.TRIGGERS WHERE condition;
比如:
SELECT * FROM INFORMATION_SCHEMA.TRIGGERS WHERE TRIGGER_NAME = 'trigger_student';
可以自己查看一下命令运行的效果
删除触发器
使用DROP TRIGGER语句可以删除MySQL中已经定义的触发器,删除触发器的基本语法为:
DROP TRIGGER [schema_name.]trigger_name;
schema_name表示数据库名称,是可选的,如果省略了schema_name,将从当前数据库中删除触发器,trigger_name是要删除的触发器的名称,比如:
DROP TRIGGER school.tri_student
触发器tri_student删除成功
使用触发器的注意点
在使用触发器的时候需要注意:对于相同的表,相同的事件只能创建一个触发器。
比如对表student创建了一个BEFORE INSERT触发器,那么如果对表student再次创建一个BEFORE INSERT触发器,MySQL将会报错,此时,只可以在表student上创建AFTER INSERT或者BEFORE UPDATE类型的触发器。灵活地运用触发器将为操作省去很多麻烦。
来源:https://blog.csdn.net/laomumu1992/article/details/82969544


猜你喜欢
- 目录前言什么是pip再说 pip, 它就像应用宝下面给我们的手机安装应用宝Centos 安装pip for python2试用pip来安装库
- 引言对 axios 二次封装,更加的可配置化、扩展性更加强大灵活通过 class 类实现,class 具备更强封装性(封装、继承、多态),通
- 为什么ASP.NET Core采用Main方法?需要记住的最重要的一点是,ASP.NET Core Web 应用程序最初作为控制台应用程序启
- 连接mysql#!/usr/bin/python#-*- coding:utf-8 -*-import timeimport pymysql
- 起因 前几天去国图拍了一本书,一本心理学方面的书,也许你问我为什么不去买一本,或者去网上找pdf。 其实吧,关于心理学方面的书可以说在市面上
- 用django开发,经常要处理用户上传的文件, 比如user模型里面如果又个人头像的字段 ImageField等等,而django在Fiel
- 我们把对象(变量)从内存中变成可存储的过程称之为序列化,比如XML,在Python中叫pi
- 简介MQTT.js 是一个开源的 MQTT 协议的客户端库,使用 JavaScript 编写,主要用于 Node.js
- 本文实例讲述了python实现简单温度转换的方法。分享给大家供大家参考。具体分析如下:这是一段简单的python代码,用户转换不同单位的温度
- <input type="button" onclick="opened('ALERT'
- 使用BootstrapValidator进行注册校验和登录错误提示,具体内容如下1、介绍在AdminEAP框架中,使用了BootstrapV
- 本文实例讲述了Go语言实现的树形结构数据比较算法。分享给大家供大家参考。具体实现方法如下:// Two binary trees may b
- 我一直很难理解Javascript语言的继承机制。它没有"子类"和"父类"的概念,也没有"
- os模块中的fork方法可以创建一个子进程。相当于克隆了父进程os.fork()子进程运行时,os.fork方法会返回0; 而父进
- 你们要的3D太阳系图片上传之后不知为何帧率降低了许多。。。日地月三体所谓三体,就是三个物体在重力作用下的运动。由于三点共面,所以三个质点仅在
- CSS的出现使网页制作者在对网页元素的控制方便许多,当然,有利必有弊,CSS只能对颜色、大小、距离等静
- 如下所示:# -*- coding: UTF-8 -*-import numpy as npimport osfrom scipy.misc
- 引言现在本地创建一个excel表,以及两个sheet,具体数据如下:sheet1: sheet2:读取excel文件pandas.
- 以前跟同事开玩笑时说过,我们遇到的用户在访谈测试过程中的表现基本上就三种类型,发泄型,赞美型和实话实说型。发泄型用户通常是在产品的使用过程中
- 现代网络应用Web APP或大型网站的后台一般只有一个,然后客户端却是各种各样的(iOS, android, 浏览器),