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,然后使用自带功能是最好的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值