开发者社区> 问答> 正文

无权限 执行 set global event_scheduler = on;

刚买下的云 数据 库rds 后  执行 set global event_scheduler = on; 提示没有超级权限

执行失败,失败原因:Access denied; you need (at least one of) the SUPER privilege(s) for this operation

展开
收起
游客x5ysjq4qejmxa 2019-03-16 22:44:33 2995 0
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}
    

    答案来源于网络,供参考,希望有所帮助。

    2019-09-29 10:14:33
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Froma single droplet toafull b 立即下载
How to Build a Successful Data 立即下载
In-Flux Limiting for a Multi-Tenant Logging Service 立即下载