Что будет с запущенным событием, если я отключу глобальный event_scheduler

Предположим, у меня есть событие в mysql с именем event_data и это вызывает хранимую процедуру data_sp, event_data срабатывает и data_sp в настоящее время работает. Сейчас занимаюсь SET GLOBAL event_scheduler = OFF; в основном отключение глобального планировщика событий.

Что будет с текущим исполнением data_sp? Будет ли он остановлен или будет продолжать работать? Если он будет остановлен, будут ли зафиксированы данные?

1 ответ

Решение

В качестве следующего доказательства концепции хранимая процедура будет продолжать работать до конца действия:

mysql> SELECT VERSION();
+-----------------+
| VERSION()       |
+-----------------+
| 5.5.22-0ubuntu1 |
+-----------------+
1 row in set (0.00 sec)

mysql> SET @@GLOBAL.event_scheduler := ON;
Query OK, 0 rows affected (0.00 sec)

mysql> DROP PROCEDURE IF EXISTS `data_sp`;
Query OK, 0 rows affected (0.00 sec)

mysql> DROP EVENT IF EXISTS `event_data`;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> DROP TABLE IF EXISTS `event_test`;
Query OK, 0 rows affected (0.00 sec)

mysql> DELIMITER //

mysql> CREATE TABLE `event_test`(
    ->     `id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    ->     `event_scheduler_on` CHAR(3),
    ->     `current_datetime` DATETIME
    -> )//
Query OK, 0 rows affected (0.00 sec)

mysql> CREATE EVENT IF NOT EXISTS `event_data`
    ->     ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 3 SECOND
    ->     DO CALL `data_sp`(10)//
Query OK, 0 rows affected (0.00 sec)

mysql> CREATE PROCEDURE `data_sp`(`max_iteration` TINYINT)
    -> BEGIN
    ->     DECLARE `iteration`, `event_scheduler_off` TINYINT DEFAULT 0;
    ->     SET `event_scheduler_off` := 3;
    ->     WHILE `iteration` < `max_iteration` DO
    ->         IF `iteration` > `event_scheduler_off` THEN
    ->             SET @@GLOBAL.event_scheduler := OFF;
    ->         END IF;
    -> 
    ->         INSERT INTO `event_test` (
    ->             `event_scheduler_on`, `current_datetime`
    ->         ) VALUES (
    ->             @@GLOBAL.event_scheduler, NOW()
    ->         );
    -> 
    ->         SET `iteration` := `iteration` + 1;
    ->         DO SLEEP(1);
    ->     END WHILE;
    -> END//
Query OK, 0 rows affected (0.00 sec)

mysql> DELIMITER ;

mysql> SELECT @@GLOBAL.event_scheduler;
+--------------------------+
| @@GLOBAL.event_scheduler |
+--------------------------+
| OFF                      |
+--------------------------+
1 row in set (0.00 sec)

mysql> SELECT
    ->     `id`,
    ->     `event_scheduler_on`,
    ->     `current_datetime`
    -> FROM
    ->     `event_test`;
+----+--------------------+---------------------+
| id | event_scheduler_on | current_datetime    |
+----+--------------------+---------------------+
|  1 | ON                 | 2010-01-01 04:00:00 |
|  2 | ON                 | 2010-01-01 04:00:01 |
|  3 | ON                 | 2010-01-01 04:00:02 |
|  4 | ON                 | 2010-01-01 04:00:03 |
|  5 | OFF                | 2010-01-01 04:00:04 |
|  6 | OFF                | 2010-01-01 04:00:05 |
|  7 | OFF                | 2010-01-01 04:00:06 |
|  8 | OFF                | 2010-01-01 04:00:07 |
|  9 | OFF                | 2010-01-01 04:00:08 |
| 10 | OFF                | 2010-01-01 04:00:09 |
+----+--------------------+---------------------+
10 rows in set (0.00 sec)
Другие вопросы по тегам