MySQL事件调度器_MySQL

Jun 01, 2016 pm 01:18 PM

bitsCN.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;
ログイン後にコピー
View Code

其中schedule的语句可以表示为:

AT TIMESTAMP [+ INTERVAL]| EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]
ログイン後にコピー
View Code

interval的单位可以有如下几种:

YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE | DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND
ログイン後にコピー
View Code

2.开启、关闭事件调度器

在使用这个功能之前必须确保event_scheduler已开启.

/*开启*/SET GLOBAL event_scheduler = 1;-- 或SET GLOBAL event_scheduler = ON;/*关闭*/SET GLOBAL event_scheduler = 0;-- 或SET GLOBAL event_scheduler = OFF; 
ログイン後にコピー
View Code

3.示例

创建测试数据库:

CREATE TABLE tst_event (createtime DATETIME);
ログイン後にコピー
View Code

创建测试用存储过程:

/*创建测试用存储过程*/CREATE PROCEDURE msp_TestEvent()BEGIN    INSERT INTO tst_event VALUES (CURRENT_TIMESTAMP);END
ログイン後にコピー
View Code

创建事件调度器:

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();
ログイン後にコピー
View Code

修改事件调度器:

/*修改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);
ログイン後にコピー
View Code

查看事件调度器:

/*查看EVENT*/   show events;-- 或select * from information_schema.events 
ログイン後にコピー
View Code

4.不同时间间隔的调度: 

一天后执行调度器:

/*一天后执行调度器T*/    CREATE EVENT e_TestEventON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 DAYDO CALL msp_TestEvent();
ログイン後にコピー
View Code

2014-02-28日执行调度器:

/*2014-02-28日执行调度器*/    CREATE EVENT e_TestEventON SCHEDULE AT TIMESTAMP '2014-02-28 00:00:00'DO CALL msp_TestEvent();
ログイン後にコピー
View Code

每天执行调度器:

/*每天执行调度器*/    CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYDO CALL msp_TestEvent();
ログイン後にコピー
View Code

一天后每天执行调度器:

/*一天后每天执行调度器*/    CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYSTARTS CURRENT_TIMESTAMP + INTERVAL 2 DAYDO CALL msp_TestEvent(); 
ログイン後にコピー
View Code

每天执行调度器,10天后停止:

/*每天执行调度器,10天后停止*/    CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYENDS CURRENT_TIMESTAMP + INTERVAL 10 DAYDO CALL msp_TestEvent(); 
ログイン後にコピー
View Code

一天后开始,每天执行调度器,10天后停止:

/*一天后开始,每天执行调度器,10天后停止*/    CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYSTARTS CURRENT_TIMESTAMP + INTERVAL 1 DAYENDS CURRENT_TIMESTAMP + INTERVAL 10 MONTHDO CALL msp_TestEvent();
ログイン後にコピー
View Code

每天执行调度器,只执行一次:

/*每天执行调度器,只执行一次*/    CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYON COMPLETION NOT PRESERVEDO CALL msp_TestEvent(); 
ログイン後にコピー
View Code

5.删除调度器

DROP EVENT [IF EXISTS] event_name
ログイン後にコピー
View CodebitsCN.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

DockerでのMySQLメモリの使用を減らします DockerでのMySQLメモリの使用を減らします Mar 04, 2025 pm 03:52 PM

DockerでのMySQLメモリの使用を減らします

Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか? Mar 19, 2025 pm 03:51 PM

Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

mysqlの問題を解決する方法共有ライブラリを開くことができません mysqlの問題を解決する方法共有ライブラリを開くことができません Mar 04, 2025 pm 04:01 PM

mysqlの問題を解決する方法共有ライブラリを開くことができません

sqliteとは何ですか?包括的な概要 sqliteとは何ですか?包括的な概要 Mar 04, 2025 pm 03:55 PM

sqliteとは何ですか?包括的な概要

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし) Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし) Mar 04, 2025 pm 03:54 PM

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド Mar 04, 2025 pm 03:49 PM

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? 人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか? Mar 21, 2025 pm 06:28 PM

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか?

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか? Mar 18, 2025 pm 12:01 PM

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?

See all articles