Home >Database >Mysql Tutorial >Detailed explanation of the use of MySQL events

Detailed explanation of the use of MySQL events

黄舟
黄舟Original
2017-08-01 17:14:084684browse

In system management or database management, it is often necessary to execute a certain command or SQL statement periodically. At this time, the mysql event will be used. To use this function, you must ensure that the mysql version is 5.1 or above.

1. First check whether the event is enabled,

SHOW VARIABLES LIKE 'event_scheduler';
SELECT @@event_scheduler;
SHOW PROCESSLIST;

星sql

Detailed explanation of the use of MySQL events

2. We first enable the mysql event, 1. Modify it through dynamic parameters: SET GLOBAL event_scheduler = ON; Note: You still need to add event_scheduler=ON to my.cnf. Because if it is not added, the mysql restart event will return to its original state.

Detailed explanation of the use of MySQL events

3. Next I create a test database table,

CREATE TABLE `test` (  
`ID` int(11) NOT NULL AUTO_INCREMENT,  
`lpnam` datetime DEFAULT NULL,  
PRIMARY KEY (`id`))
ENGINE=InnoDB 
AUTO_INCREMENT=106 
DEFAULT CHARSET=utf8

Create a Database table as test

Detailed explanation of the use of MySQL events

4. Next we create mysql event,

CREATE EVENT IF NOT EXISTS test123 ON SCHEDULE EVERY 3 SECOND
ON COMPLETION PRESERVE
DO INSERT INTO ceshisy(lpname) VALUES(NOW());

execute sql creation mysql event

Detailed explanation of the use of MySQL events

5. After the creation is completed, let’s check whether it was executed and check the database table

Detailed explanation of the use of MySQL events

6. Summarize the grammar:

DEFINER: 定义事件执行的时候检查权限的用户。
ON SCHEDULE schedule: 定义执行的时间和时间间隔。
ON COMPLETION [NOT] PRESERVE: 定义事件是一次执行还是永久执行,默认为一次执行,即NOT PRESERVE。
ENABLE | DISABLE | DISABLE ON SLAVE: 定义事件创建以后是开启还是关闭,以及在从上关闭。如果是从服务器自动同步主上的创建事件的语句的话,会自动加上DISABLE ON SLAVE。
COMMENT 'comment': 定义事件的注释。


The above is the detailed content of Detailed explanation of the use of MySQL events. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn