日期:2014-05-16  浏览次数:20926 次

mysql 计划任务执行

由于论坛财富值每月免费赠送部分都是人工每月初收到去执行一个sql语句。

经常因为某些原因,就忘记了赠送财富值的问题。

于是决定用计划任务来实现。每月自动执行sql语句。

在google的帮助下。

我发现了自MySQL5.1.6起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务。

当时也没怎么看直接就准备用这个功能来实现我要执行的计划任务(周期任务)。

具体语法如下:

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}

?

?

参照语法我的语句是

?

?

CREATE EVENT free ON SCHEDULE EVERY 1 MONTH DO UPDATE  `sends`.`bbs_money` SET  `free` =  '150';
?

?

然而一直都是都有语法错误

?

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near EVENT free ON SCHEDULE EVERY 1 MONTH DO UPDATE  `sends`.`bbs_money` SET  `free` =  '150';

?

无论怎样排查也没发现什么错误。。。

万能的google似乎也没什么办法,正在忧郁之时,想起了自己mysql的版本似乎太低,于是通过

?

mysql -V
?

查看了当前数据库的版本为5.0,这就解释了为什么会出现语法错误。

?

======================================================================

?

因为暂时没时间升级数据库版本,所以只有通过linux系统自带的crontab来执行sql任务。

?

然后新建个账户free:

?

CREATE USER 'itest'@'localhost' IDENTIFIED BY  'abc';
?

并赋予仅对free执行update的权限:

?

GRANT UPDATE (
`free`
) ON  `sendscc`.`bbs_money` TO  'free'@'localhost';
?

?

这样就可以对安全性会有一定增加。

现在来添加计划任务:

]#crontab -e

?

00 00 1 * * /usr/local/mysql/bin/mysql -ufree -pabc -h localhost -e 'UPDATE  `sends`.`bbs_money` SET  `free` =  150';
?

?

这样就可以让mysql执行周期任务了。不过安全性低,所以尽快升级mysql,然后使用自带功能是最好的。