mysql定时任务

来源:互联网 发布:mac删除酷我音乐 编辑:程序博客网 时间:2024/06/05 08:13

一、使用过程
1.查看当前是否已开启事件计划(调度器)有3种方法:


1
2
3
SHOW VARIABLES LIKE'event_scheduler';
SELECT@@event_scheduler;
SHOW PROCESSLIST;

 
2. 开启事件计划(调度器)开关有4种方法:


1
2
3
4
SETGLOBAL event_scheduler = 1;
SET@@global.event_scheduler = 1;
SETGLOBAL event_scheduler = ON;
SET@@global.event_scheduler = ON;

键值1或者ON表示开启;0或者OFF表示关闭;
 
3.关于事件计划的权限:
单独使用event调用SQL语句时,查看和创建需要用户具有event权限,调用该SQL语句时,需要用户具有执行该SQL的权限。Event权 限的设置保存在mysql.user表和mysql.db表的Event_priv字段中。(FLUSH PRIVILEGES;)
当event和procedure配合使用的时候,查看和创建存储过程需要用户具有create routine权限,调用存储过程执行时需要使用excute权限,存储过程调用具体的SQL语句时,需要用户具有执行该SQL的权限。


1
SELECTHOST,USER,Event_privFROMmysql.user;

201653145320225.jpg (339×169)

获取当前登陆的用户和数据库:SELECT CURRENT_USER(), SCHEMA();
从Figure1可以知道bfsql@%是没有Event_priv权限的,在该用户下创建事件的时候会出现下面的错误:
Error Code: 1044Access denied for user 'bfsql'@'%' to database 'blog'
如果出现上面的错误,执行下面的SQL就可以给bfsql@%赋予创建Event的权限:


1
2
UPDATEmysql.userSET Event_priv = 'Y'WHERE HOST='%'AND USER='bfsql';
FLUSHPRIVILEGES;

最后,你可以通过SHOW GRANTS FOR 'bfsql'@'%';查看所有权限;
 
4.创建事件:
(1)创建事件的语法如下:


1
2
3
4
5
6
CREATEEVENT [IF NOTEXISTS] event_name
ONSCHEDULE schedule
[ONCOMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT'comment']
DO sql_statement

(2)创建事件的示例如下:


1
2
3
4
5
6
7
8
DELIMITER $$
CREATEEVENT IF NOTEXISTS e_blog
ONSCHEDULE EVERY 30 SECOND
ONCOMPLETION PRESERVE
DOBEGIN
CALL MoveBlogData();
END$$
DELIMITER ;

 
DO sql_statement字段表示该event需要执行的SQL语句或存储过程。这里的SQL语句可以是复合语句,使用BEGIN和END标识符将复合SQL语句按照执行顺序放在之间。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
--从现在开始每隔九天定时执行
CREATEEVENT EVENT1
ONSCHEDULE EVERY 9 DAYSTARTS NOW()
ONCOMPLETION PRESERVE ENABLE
DO
  BEGIN
    CALL TOTAL();
  END
  
  
--每个月的一号凌晨1 点执行
CREATEEVENT EVENT2  
ONSCHEDULE EVERY 1 MONTHSTARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1DAY), INTERVAL 1 MONTH),INTERVAL 1 HOUR)
ONCOMPLETION PRESERVE ENABLE
DO
  BEGIN
    CALL STAT();
  END
  
---每个季度一号的凌晨2点执行
CREATEEVENT TOTAL_SEASON_EVENT
ONSCHEDULE EVERY 1 QUARTER STARTS DATE_ADD(DATE_ADD(DATE( CONCAT(YEAR(CURDATE()),'-',ELT(QUARTER(CURDATE()),1,4,7,10),'-',1)),INTERVAL 1 QUARTER),INTERVAL 2 HOUR)
ONCOMPLETION PRESERVE ENABLE
DO
  BEGIN
    CALL SEASON_STAT();
  END
  
--每年1月1号凌晨四点执行
CREATEEVENT TOTAL_YEAR_EVENT
ONSCHEDULE EVERY 1 YEARSTARTS DATE_ADD(DATE(CONCAT(YEAR(CURDATE()) + 1,'-',1,'-',1)),INTERVAL 4 HOUR)
ONCOMPLETION PRESERVE ENABLE
DO
  BEGIN
    CALL YEAR_STAT();
  END

 
5.事件开启与关闭:
开启某事件:


1
ALTEREVENT e_test ONCOMPLETION PRESERVE ENABLE;

关闭某事件:


1
ALTEREVENT e_test ONCOMPLETION PRESERVE DISABLE;

二、实例:
mysql定时器是系统给提供了event,而oracle里面的定时器是系统给提供的job。废话少说,下面创建表:


1
2
3
4
5
6
7
createtable mytable (
idintauto_increment notnull,
namevarchar(100)notnull default '',
introduce text notnull,
createtimetimestampnot null,
constraintpk_mytable primarykey(id)
)


创建存储过程,这里的存储过程主要提供给mysql的定时器event来调用去执行:


1
2
3
4
createprocedure mypro()
BEGIN
insertinto mytable (name,introduce,createtime)values('1111','inner mongolia',now());
end;

这里只是简单的写了一下,只是为了说明例子。


紧接着创建mysql的定时器event:


1
2
3
4
createevent if notexists eventJob
onschedule every 1 second
oncompletion PRESERVE
do call mypro();

这里设置为每一秒执行一次

至此所有的准备工作已经写完了,做完这些,mysql要想利用定时器必须的做准备工作,就是把mysql的定时器给开启了:


1
2
SETGLOBAL event_scheduler = 1; -- 启动定时器
SETGLOBAL event_scheduler = 0; -- 停止定时器

紧接着还要开启事件:


1
2
3
4
5
ALTEREVENT eventJob ONCOMPLETION PRESERVE ENABLE;  -- 开启事件
ALTEREVENT eventJob ONCOMPLETION PRESERVE DISABLE; -- 关闭事件
 
 
SHOW VARIABLES LIKE'%sche%';-- 查看定时器状态

至此,你去数据库里面的表mytable里面看下,系统会每隔一秒去插入一条数据,嘻嘻,任务完成了。


1
select* frommytable
原创粉丝点击