2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > 一起聊聊MySQL基础之触发器和事件

一起聊聊MySQL基础之触发器和事件

时间:2024-07-08 04:51:01

相关推荐

一起聊聊MySQL基础之触发器和事件

数据库|mysql教程

mysql

数据库-mysql教程

shop 5.0源码下载,vscode的lua开发,ubuntu键盘关机,tomcat估算线程,sqlite插入日期数据,前端框架用脚手架搭建好吗,爬虫抓取淘宝商品点击率,php pdo 存储过程,江苏在线seo推广,网站模板论坛,娱乐新闻网页设计代码,手机wap购物网站模板lzw

触发器

仿哔哩哔哩网页源码,vscode折叠所有方法,ubuntu 黑屏鼠标,tomcat 热部署机制,rcurl爬虫乱码,php 创建数据表,潜江茶叶seo推广哪里好,网站悬浮窗,仿58同城最新模板lzw

我们使用MySQL的过程中可能会有下边这些需求:

域名源码,vscode博客,UBUNTU软件下载文档,tomcat启动控制台中文乱码,sqlite 免安装,动态网页设计模板下载,云服务器iis配置,checkbox 美化插件,前端框架管理推荐,爬虫卫生间,php判断图片是否存在,seo灰,鬼姐姐网站怎么样,数据库网页模板下载,无需注册网站模板下载,jquery 页面循环滚动代码,学生成绩管理系统数据库设计,秒杀小程序 源码模块lzw

在向t1表插入或更新数据之前对自动对数据进行校验,要求m1列的值必须在1~10之间,校验规则如下:

如果插入的记录的m1列的值小于1,则按1插入。如果m1列的值大于10,则按10插入。

在向t1表中插入记录之后自动把这条记录插入到t2表。

也就是我们在对表中的记录做增、删、改操作前和后都可能需要让MySQL服务器自动执行一些额外的语句,这个就是所谓的触发器的应用场景。

创建触发器

我们看一下定义触发器的语句:

CREATE TRIGGER 触发器名{BEFORE|AFTER}{INSERT|DELETE|UPDATE}ON 表名FOR EACH ROWBEGIN 触发器内容END

其中{BEFORE|AFTER}表示触发器内容执行的时机,它们的含义如下:

{INSERT|DELETE|UPDATE}表示具体的语句,MySQL中目前只支持对INSERTDELETEUPDATE这三种类型的语句设置触发器。

FOR EACH ROW BEGIN ... END表示对具体语句影响的每一条记录都执行我们自定义的触发器内容:

对于INSERT语句来说,FOR EACH ROW影响的记录就是我们准备插入的那些新记录。

对于DELETE语句和UPDATE语句来说,FOR EACH ROW影响的记录就是符合WHERE条件的那些记录(如果语句中没有WHERE条件,那就是代表全部的记录)。

因为MySQL服务器会对某条语句影响的所有记录依次调用我们自定义的触发器内容,所以针对每一条受影响的记录,我们需要一种访问该记录中的内容的方式,MySQL提供了NEWOLD两个单词来分别代表新记录和旧记录,它们在不同语句中的含义不同:

对于INSERT语句设置的触发器来说,NEW代表准备插入的记录,OLD无效。对于DELETE语句设置的触发器来说,OLD代表删除前的记录,NEW无效。对于UPDATE语句设置的触发器来说,NEW代表修改后的记录,OLD代表修改前的记录。

现在我们可以正式定义一个触发器了:

mysql> delimiter $mysql> CREATE TRIGGER bi_t1 -> BEFORE INSERT ON t1 -> FOR EACH ROW -> BEGIN ->IF NEW.m1SET NEW.m1 = 1; ->ELSEIF NEW.m1 > 10 THEN -> SET NEW.m1 = 10; ->END IF; -> END $Query OK, 0 rows affected (0.02 sec)mysql> delimiter ;mysql>

我们对t1表定义了一个名叫bi_t1触发器,它的意思就是在对t1表插入新记录之前,对准备插入的每一条记录都会执行BEGIN ... END之间的语句,NEW.列名表示当前待插入记录指定列的值。现在t1表中一共有4条记录:

mysql> SELECT * FROM t1;+------+------+| m1 | n1 |+------+------+| 1 | a || 2 | b || 3 | c || 4 | d |+------+------+4 rows in set (0.00 sec)mysql>

我们现在执行一下插入语句并再次查看一下t1表的内容:

mysql> INSERT INTO t1(m1, n1) VALUES(5, e), (100, z);Query OK, 2 rows affected (0.00 sec)Records: 2 Duplicates: 0 Warnings: 0mysql> SELECT * FROM t1;+------+------+| m1 | n1 |+------+------+| 1 | a || 2 | b || 3 | c || 4 | d || 5 | e || 10 | z |+------+------+6 rows in set (0.00 sec)mysql>

这个INSERT语句影响的记录有两条,分别是(5, e)(100, z),这两条记录将分别执行我们自定义的触发器内容。很显然(5, e)被成功的插入到了t1表中,而(100, z)插入到表中后却变成了(10, z),这个就说明我们的bi_t1触发器生效了!

上边只是举了一个对INSERT语句设置BEFORE触发器的例子,对DELETEUPDATE操作设置BEFORE或者AFTER触发器的过程是类似的,就不赘述了。

查看和删除触发器

查看当前数据库中定义的所有触发器的语句:

SHOW TRIGGERS;

查看某个具体的触发器的定义:

SHOW CREATE TRIGGER 触发器名;

删除触发器:

DROP TRIGGER 触发器名;

这几个命令太简单了,就不举例子了啊~

触发器使用注意事项

触发器内容中不能有输出结果集的语句。

比方说:

mysql> delimiter $mysql> CREATE TRIGGER ai_t1 -> AFTER INSERT ON t1 -> FOR EACH ROW -> BEGIN ->SELECT NEW.m1, NEW.n1; -> END $ERROR 1415 (0A000): Not allowed to return a result set from a triggermysql>

显示的ERROR的意思就是不允许在触发器内容中返回结果集!

触发器内容中NEW代表记录的列的值可以被更改,OLD代表记录的列的值无法更改。

NEW代表新插入或着即将修改后的记录,修改它的列的值将影响INSERT和UPDATE语句执行后的结果,而OLD代表修改或删除之前的值,我们无法修改它。比方说如果我们非要这么写那就会报错的:

mysql> delimiter $mysql> CREATE TRIGGER bu_t1 -> BEFORE UPDATE ON t1 -> FOR EACH ROW -> BEGIN ->SET OLD.m1 = 1; -> END $ERROR 1362 (HY000): Updating of OLD row is not allowed in triggermysql>

可以看到提示的错误中显示在触发器中OLD代表的记录是不可被更改的。

在BEFORE触发器中,我们可以使用SET NEW.列名 = 某个值的形式来更改待插入记录或者待更新记录的某个列的值,但是这种操作不能在AFTER触发器中使用,因为在执行AFTER触发器的内容时记录已经被插入完成或者更新完成了。

比方说如果我们非要这么写那就会报错的:

mysql> delimiter $mysql>CREATE TRIGGER ai_t1 ->AFTER INSERT ON t1 ->FOR EACH ROW ->BEGIN -> SET NEW.m1 = 1; ->END $ERROR 1362 (HY000): Updating of NEW row is not allowed in after triggermysql>

可以看到提示的错误中显示在AFTER触发器中是不允许更改NEW代表的记录的。

如果我们的BEFORE触发器内容执行过程中遇到了错误,那这个触发器对应的具体语句将无法执行;如果具体的操作语句执行过程中遇到了错误,那与它对应的AFTER触发器的内容将无法执行。

事件

有时候我们想让MySQL服务器在某个时间点或者每隔一段时间自动地执行一些语句,这时候就需要去创建一个事件

创建事件

创建事件的语法如下:

CREATE EVENT 事件名ON SCHEDULE{ AT 某个确定的时间点|EVERY 期望的时间间隔 [STARTS datetime][END datetime]}DOBEGIN 具体的语句END

事件支持两种类型的自动执行方式:

在某个确定的时间点执行。

比方说:

CREATE EVENT insert_t1_eventON SCHEDULEAT -09-04 15:48:54DOBEGIN INSERT INTO t1(m1, n1) VALUES(6, f);END

我们在这个事件中指定了执行时间是-09-04 15:48:54,除了直接填某个时间常量,我们也可以填写一些表达式:

CREATE EVENT insert_t1ON SCHEDULEAT DATE_ADD(NOW(), INTERVAL 2 DAY)DOBEGIN INSERT INTO t1(m1, n1) VALUES(6, f);END

其中的DATE_ADD(NOW(), INTERVAL 2 DAY)表示该事件将在当前时间的两天后执行。

每隔一段时间执行一次。

比方说:

CREATE EVENT insert_t1ON SCHEDULEEVERY 1 HOURDOBEGIN INSERT INTO t1(m1, n1) VALUES(6, f);END

其中的EVERY 1 HOUR表示该事件将每隔1个小时执行一次。默认情况下,采用这种每隔一段时间执行一次的方式将从创建事件的事件开始,无限制的执行下去。我们也可以指定该事件开始执行时间和截止时间:

CREATE EVENT insert_t1ON SCHEDULEEVERY 1 HOUR STARTS -09-04 15:48:54 ENDS -09-16 15:48:54DOBEGIN INSERT INTO t1(m1, n1) VALUES(6, f);END

如上所示,该事件将从’-09-04 15:48:54’开始直到’-09-16 15:48:54’为止,中间每隔1个小时执行一次。

在创建好事件之后我们就不用管了,到了指定时间,MySQL服务器会帮我们自动执行的。

查看和删除事件

查看当前数据库中定义的所有事件的语句:

SHOW EVENTS;

查看某个具体的事件的定义:

SHOW CREATE EVENT 事件名;

删除事件:

DROP EVENT 事件名;

这几个命令太简单了,就不举例子了啊~

事件使用注意事项

默认情况下,MySQL服务器并不会帮助我们执行事件,除非我们使用下边的语句手动开启该功能:

mysql> SET GLOBAL event_scheduler = ON;Query OK, 0 rows affected (0.00 sec)mysql>

mysql视频教学

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。