MySQL事件调度器_MySQL
Jun 01, 2016 pm 01:18 PMbitsCN.com
MySQL 5.1 中新增了事件调度器这一个功能。可以实现类似于SQL Server的Job功能。
1.语法:


CREATE EVENT [IF NOT EXISTS] event_nameON SCHEDULE schedule [ON COMPLETION [NOT] PRESERVE][ENABLE | DISABLE][COMMENT 'comment']DO sql_statement;
로그인 후 복사
其中schedule的语句可以表示为:


AT TIMESTAMP [+ INTERVAL]| EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]
로그인 후 복사
interval的单位可以有如下几种:


YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE | DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND
로그인 후 복사
2.开启、关闭事件调度器:
在使用这个功能之前必须确保event_scheduler已开启.


/*开启*/SET GLOBAL event_scheduler = 1;-- 或SET GLOBAL event_scheduler = ON;/*关闭*/SET GLOBAL event_scheduler = 0;-- 或SET GLOBAL event_scheduler = OFF;
로그인 후 복사
3.示例:
创建测试数据库:


CREATE TABLE tst_event (createtime DATETIME);
로그인 후 복사
创建测试用存储过程:


/*创建测试用存储过程*/CREATE PROCEDURE msp_TestEvent()BEGIN INSERT INTO tst_event VALUES (CURRENT_TIMESTAMP);END
로그인 후 복사
创建事件调度器:


CREATE EVENT IF NOT EXISTS me_TestEvent ON SCHEDULE EVERY 10 SECOND STARTS '2014-02-28 16:45:00' ENDS DATE_ADD('2014-02-28 16:46:00',INTERVAL 1 SECOND) DO CALL msp_TestEvent();
로그인 후 복사
修改事件调度器:


/*修改EVENT*/ ALTER EVENT me_TestEvent ON SCHEDULE EVERY 10 SECOND STARTS '2014-02-27 16:45:00' ENDS DATE_ADD('2014-02-27 16:46:00',INTERVAL 1 SECOND) DO INSERT INTO tst_event VALUES (CURRENT_TIMESTAMP);
로그인 후 복사
查看事件调度器:


/*查看EVENT*/ show events;-- 或select * from information_schema.events
로그인 후 복사
4.不同时间间隔的调度:
一天后执行调度器:


/*一天后执行调度器T*/ CREATE EVENT e_TestEventON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 DAYDO CALL msp_TestEvent();
로그인 후 복사
2014-02-28日执行调度器:


/*2014-02-28日执行调度器*/ CREATE EVENT e_TestEventON SCHEDULE AT TIMESTAMP '2014-02-28 00:00:00'DO CALL msp_TestEvent();
로그인 후 복사
每天执行调度器:


/*每天执行调度器*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYDO CALL msp_TestEvent();
로그인 후 복사
一天后每天执行调度器:


/*一天后每天执行调度器*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYSTARTS CURRENT_TIMESTAMP + INTERVAL 2 DAYDO CALL msp_TestEvent();
로그인 후 복사
每天执行调度器,10天后停止:


/*每天执行调度器,10天后停止*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYENDS CURRENT_TIMESTAMP + INTERVAL 10 DAYDO CALL msp_TestEvent();
로그인 후 복사
一天后开始,每天执行调度器,10天后停止:


/*一天后开始,每天执行调度器,10天后停止*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYSTARTS CURRENT_TIMESTAMP + INTERVAL 1 DAYENDS CURRENT_TIMESTAMP + INTERVAL 10 MONTHDO CALL msp_TestEvent();
로그인 후 복사
每天执行调度器,只执行一次:


/*每天执行调度器,只执行一次*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYON COMPLETION NOT PRESERVEDO CALL msp_TestEvent();
로그인 후 복사
5.删除调度器:


DROP EVENT [IF EXISTS] event_name
로그인 후 복사
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

인기 기사
Repo : 팀원을 부활시키는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
헬로 키티 아일랜드 어드벤처 : 거대한 씨앗을 얻는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
스플릿 소설을이기는 데 얼마나 걸립니까?
3 몇 주 전
By DDD

인기 기사
Repo : 팀원을 부활시키는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
헬로 키티 아일랜드 어드벤처 : 거대한 씨앗을 얻는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
스플릿 소설을이기는 데 얼마나 걸립니까?
3 몇 주 전
By DDD

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제
Gmail 이메일의 로그인 입구는 어디에 있나요?
7302
9


자바 튜토리얼
1622
14


Cakephp 튜토리얼
1342
46


라라벨 튜토리얼
1259
25


PHP 튜토리얼
1207
29



Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?
