石家庄自助建站软件那个网站教做菜做的好
2026/4/17 22:37:54 网站建设 项目流程
石家庄自助建站软件,那个网站教做菜做的好,做网站引流的利润,互联网销售是做什么的Event即事件#xff0c;也是一种数据库对象#xff0c;又叫时间触发器或者事件调度器#xff0c;与triggers的事件触发不同#xff0c;tiggers会因为update、delete、insert等事件触发#xff0c;而event类似与linux crontab计划任务#xff0c;用于时间触发#xff0c;…Event即事件也是一种数据库对象又叫时间触发器或者事件调度器与triggers的事件触发不同tiggers会因为update、delete、insert等事件触发而event类似与linux crontab计划任务用于时间触发当到了设定执行时间时系统会触发相关的SQL语句或存储过程相当于我们给存储过程创建了定时任务。适用范围对于每隔一段时间就有固定需求的操作如创建表删除数据、插入数据修改数据等操作可以使用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、year3、指定开始时间的重复计划每天在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 DEFINERrootlocalhost PROCEDURE student_bak_pro() BEGIN insert into student_bak select * from student t where not EXISTS (select * from student_bak t1 where t1.snot.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用法详解”的内容大家觉得有用的话记得关注公众号哦。

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询