川石教育
全国咨询热线:136-9172-9932
  1. 首页 > 资讯与干货 > 常见问题

Mysql中event用法详解,零基础快速入门系列!

作者:川石学院 日期:2021-06-23 13:45:45 点击数:

  Event即事件,也是一种数据库对象,又叫时间触发器或者事件调度器,与triggers的事件触发不同,tiggers会因为update、delete、insert等事件触发,而event类似与linux crontab计划任务,用于时间触发,当到了设定执行时间时,系统会触发相关的SQL语句或存储过程,相当于我们给存储过程创建了定时任务。

Mysql中event用法详解,零基础快速入门系列!(图1)

  适用范围:对于每隔一段时间就有固定需求的操作,如创建表,删除数据、插入数据,修改数据等操作,可以使用event来处理。

  例如:在每月的1日凌晨1点自动创建下个月需要使用的三张表;在每月第一天时查询汇总上月商品的销售汇总信息,然后将这些信息插入到汇总信息表里。这些情况都可以使用event来处理。

  一、Event创建语法

  •   CREATE Event [IF NOT EXISTS] event_name -- 创建使用create event

  •   ON SCHEDULE schedule -- on schedule 什么时候来执行,执行频率

  •   [ON COMPLETION [NOT] PRESERVE] -- 调度计划执行完成后是否还保留

  •   [ENABLE | DISABLE] -- 是否开启事件,默认开启

  •   [COMMENT 'comment'] -- 事件的注释

  •   DO event_body; -- 这个调度计划要做什么?

  •   创建语法中[]里的内容是可以省略的。

  •   [IF NOT EXISTS]如果新建的event_name系统里不存在,则创建一个新的,如果已经存在了,则提示已经存在。如果省略的话,系统里不存在新的event_name则创建成功,如果已经存在了,会保存。

  •   [ON COMPLETION [NOT] PRESERVE 如果带了not当事件执行完后,就自动删除,不保留事件。如果不加not事件执行完会保留下来,该项不写的时候,默认是执行完事件保留下来。

  •   [ENABLE | DISABLE]ENABLE时事件开启,当到了事件执行时间,系统会自动执行event_body里定义的语句,如果设置的是DiSABLE则事件关闭,到了执行时间,事件也不会执行。该项没有设置时,默认为事件开启。

  •   [COMMENT 'comment']comment是事件注释,对事件进行解释说明。

  •   event_body事件主体,可以是单条DML语句,可以是多条DML语句,多条时需要写在begin……end之间,也可调用存储过程。

  二、执行时间说明

  执行时间说明:

  1、单次计划

  在2019年2月1日4点执行一次

  on schedule at '2019-02-01 04:00:00’

  2、重复计划

  on schedule every 1 second 每秒执行一次

  on schedule every 1 minute 每分钟执行一次

  也可以是hour、day、week、month、year

  3、指定开始时间的重复计划

  每天在20:00:00执行一次

  on schedule every 1 day starts ‘2021-6-16 20:00:00'

  三、如何查看Event

  •   查看有哪些event

  Show events; 或者通过Select * from information_schema.events;

  •   查看event具体内容

  SHOW CREATE EVENT event_name1;

  •   删除event

  DROP EVENT event_name;

  •   修改event

  可以先删除,再重新创建

  也可以ALTER EVENT event_name …… 省略号后边的内容和创建event一样

  四、实例

  先创建一个表student_bak,用此表来备份student表的数据;

  create table student_bak select * from student;

  接着,我们创建存储过程student_bak_pro,用来备份student表中的最新数据

  •   CREATE DEFINER=`root`@`localhost` PROCEDURE `student_bak_pro`()

  •   BEGIN

  •   insert into student_bak select * from student t where not EXISTS (select * from student_bak t1 where t1.sno=t.sno);

  •   COMMIT;

  •   END

  然后,我们再创建event,让系统每3秒自动执行以下存储过程student_bak_pro

  •   CREATE Event student_bak_event

  •   ON SCHEDULE every 3 second

  •   ON COMPLETION PRESERVE

  •   DO call student_bak_pro();

  最后,我们给student表新插入三条条数据,然后我们去观察student_bak表里数是不是也插入了最新的数据。

  •   INSERT INTO student VALUES (2008063, 'Penqun63', '男', 12, '2009-02-24', NULL),(2008064, 'Penqun63', '男', 12, '2009-02-24', NULL),

  •   (2008065, 'Penqun65', '男', 12, '2009-02-24', NULL);  

Mysql中event用法详解,零基础快速入门系列!(图2)

  本章主要讲解了关于“Mysql中event用法详解”的内容,大家喜欢的话记得每天来这里和小编一起学习涨薪技能。识别下方二维码,免费领取学习课件、视频哦。(笔芯)  

Mysql中event用法详解,零基础快速入门系列!(图3)

  附:川石信息全国校区最新开班时间,课程资料获取13691729932(微信同号)。  

Mysql中event用法详解,零基础快速入门系列!(图4)


相关文章
  • 亚马逊运营成功转行软件测试,薪资13K表示很满意!2021-06-23 13:45:45
  • 西安川石的兰朋友喊你来当他的学弟学妹啦!2021-06-23 13:45:45
  • 国外的月亮也不一定比国内测试猿的年薪美~2021-06-23 13:45:45
  • 建筑工程专业朱同学成功转行为软件测试人!2021-06-23 13:45:45
  • 财务管理专业转行软件测试月薪甩会计几条街!2021-06-23 13:45:45
  • 只有技术沉淀才能成功上岸,深圳就业薪资13K!2021-06-23 13:45:45
  • 薪资11K!实现自我价值,从掌握一门IT技术开始...2021-06-23 13:45:45
  • 文科生转行软件测试照样拿下高薪15K!2021-06-23 13:45:45
  • 恭喜罗同学喜提19.5K,成功入行软件测试!2021-06-23 13:45:45
  • 毕业1年,迷茫的他最终选择转行软件测试2021-06-23 13:45:45