navicat下mysql任务计划
博客专区 > HTCKF 的博客 > 博客详情
navicat下mysql任务计划
HTCKF 发表于3年前
navicat下mysql任务计划
  • 发表于 3年前
  • 阅读 740
  • 收藏 11
  • 点赞 0
  • 评论 1

腾讯云 技术升级10大核心产品年终让利>>>   

摘要: 对于mysql的计划任务需要注意是否开启了此功能,SHOW VARIABLES LIKE 'event_scheduler';

对于mysql的计划任务需要注意以下两点

1.否开启了此功能,SHOW VARIABLES LIKE 'event_scheduler';

如果没有开启需要在my.ini or my.cnf 中的
[mysqld]
添加 event_scheduler=ON

2.如果客户端远程访问,确认是否授权用户:

ERROR 1044: Access denied for user: '@127.0.0.1 ' to database 'mysql'

说明你没有将权限下放到远端连接帐户上,由于mysql的安全性在不断的提高,权限设置默认是拒绝的,你必须自己开放权限。

在服务器上用mysql -h 192.168.0.1 -u root -p mysql命令登录mysql数据库

然后用grant命令下放权限。

GRANT ALL PRIVILEGES ON *.* TO root@localhost IDENTIFIED BY 'root-password' WITH GRANT OPTION;

GRANT ALL PRIVILEGES ON *.* TO root@127.0.0.1 IDENTIFIED BY 'root-password' WITH GRANT OPTION;

GRANT ALL PRIVILEGES ON *.* TO root@'%' IDENTIFIED BY 'root-password' WITH GRANT OPTION;

例如:

  GRANT   ALL   PRIVILEGES   ON   *.*   TO   root@'%'   identified   by  '123456'  

注意:自己根据情况修改以上命令中的 “用户”“ip地址”“密码”。

完成此两步骤后可以使用客户端进行任务的创建了,这里仅列出创建每天执行一次的定时任务,当前时间+6小时后开启,直接上代码:

CREATE EVENT `EVENT_EMULATE_STATISTICS`
ON SCHEDULE EVERY 1 DAY STARTS CURRENT_TIMESTAMP + INTERVAL 6 HOUR
ON COMPLETION NOT PRESERVE
ENABLE
DO
CALL pro_event_emulate_statistics()
;
DROP PROCEDURE IF EXISTS `pro_event_emulate_statistics`;

CREATE DEFINER = `root`@`%` PROCEDURE `pro_event_emulate_statistics`()
BEGIN
	自定义
END;

3.测试时需要注意服务器时间和本地时间是否一致,以免测试时引起误差

通过设定全局变量event_scheduler 的值即可动态的控制事件调度器是否启用。  
查看是否event_scheduler开启 mysql> SHOW VARIABLES LIKE '%event%'; 
设置开启 mysql> SET GLOBAL event_scheduler=ON; 

详细功能参考开源中国博客:http://www.oschina.net/question/4873_20927


共有 人打赏支持
粉丝 5
博文 36
码字总数 10749
评论 (1)
同一天空
good ways! i like it
×
HTCKF
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: