如何写mysql的定时任务

如何写mysql的定时任务,第1张

mysql的定时任务一般用event(事件)来完成,触发器无法完成。

一、通过mysql的命令行客户端来完成

1、set global event_scheduler =1//开启event_scheduler

执行这个语句如果出现,可在mysql的配置文档中设置[mysqld]段中添加 event_scheduler=ON

如果重启mysql;这种情况下依然出错,Error Code: 1290. The MySQL server is running with the --event-scheduler=DISABLED

or --skip-grant-tables option so it cannot execute this statement,这个错误是说启动服务器时如果指定了--skip-grant-tables选项,则event_scheduler则自动被设置为DISABLED。命令行或配置文件的设置都会被覆盖。建议重现安装mysql或是修改启动参数(在系统服务中指定)。

查看event_scheduler状态:show status like '%event%'或SELECT @@event_scheduler

2、CREATE PROCEDURE Mypro() //创建存储过程

BEGIN

update userinfo SET endtime = now() WHERE id = '155'

END

3、创建event My_enevt,每隔三十秒执行一次

create event if not exists e_test

on schedule every 30 second

on completion preserve

do call Mypro()

4、关闭事件

alter event e_test ON COMPLETION PRESERVE DISABLE

5、开启事件

alter event e_test ON COMPLETION PRESERVE ENABLE

语法:

CREATE EVENT [IF NOT EXISTS] event_name ON SCHEDULE schedule [ON COMPLETION

[NOT] PRESERVE] [ENABLE | DISABLE] [COMMENT 'comment'] DO sql_statement

schedule: AT TIMESTAMP [+ INTERVAL INTERVAL] | EVERY INTERVAL [STARTS TIMESTAMP]

[ENDS TIMESTAMP] INTERVAL: quantity {YEAR | QUARTER | MONTH | DAY | HOUR |

MINUTE | WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE | DAY_SECOND |

HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}

 if (myreader.HasRows)

{

MessageBox.Show(myreader.GetString("email") )

}

}

myreader.Close()

mycon.Close()

推荐资料的话,我是没有了,因为我压根就没看过书。

我学习的时候只看过php一百的视频,其它的学习都是从网上找资料的,网上的学习资料特别丰富,你最好以应用为先,再来学习,哪怕自己独立制作一套程序,然后有什么不懂的,就去网上查找相应的解决办法。

另外,mysql是无法独立运行的,它的需要依靠外部程序对其进行访问,向它提交 *** 作语句,这样它的才能体现它的的功能,一般和Mysql靠得最近的,当属php了,不过其它的程序也可以,什么c++啦、java啦、asp啦,这些都能链接mysql,如果你想让mysql独立运行,那是不可能的。

如果你想用php等语言来执行mysql的定时,也是不现实的,除非你加入js之类的主动刷新代码,毕竟php程序是被动型的程序,它并不能主动运行,是需要浏览器或特定程序对其进行触发才能执行的。

如果你用c++/java等程序来链接数据库的话,这个想法倒是可行,不过如果你真用了它们的话,也就没有必要链接mysql来实现它了。

如果你觉得你想研究一些类似本地软件等技术的话,建议你不要学mysql,而要去学c语言啦、java啦这些东西。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8503441.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-17
下一篇 2023-04-17

发表评论

登录后才能评论

评论列表(0条)

保存