409 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
		
		
			
		
	
	
			409 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
|  | drop database if exists events_test; | |||
|  | create database events_test; | |||
|  | use events_test; | |||
|  | create event e_26 on schedule at '2017-01-01 00:00:00' disable do set @a = 5; | |||
|  | select db, name, body, definer, convert_tz(execute_at, 'UTC', 'SYSTEM'), on_completion from mysql.event; | |||
|  | db	name	body	definer	convert_tz(execute_at, 'UTC', 'SYSTEM')	on_completion | |||
|  | events_test	e_26	set @a = 5	root@localhost	2017-01-01 00:00:00	DROP | |||
|  | drop event e_26; | |||
|  | create event e_26 on schedule at NULL disable do set @a = 5; | |||
|  | ERROR HY000: Incorrect AT value: 'NULL' | |||
|  | create event e_26 on schedule at 'definitely not a datetime' disable do set @a = 5; | |||
|  | ERROR HY000: Incorrect AT value: 'definitely not a datetime' | |||
|  | set names utf8; | |||
|  | create event задачка on schedule every 123 minute starts now() ends now() + interval 1 month do select 1; | |||
|  | drop event задачка; | |||
|  | set event_scheduler=off; | |||
|  | ERROR HY000: Variable 'event_scheduler' is a GLOBAL variable and should be set with SET GLOBAL | |||
|  | set global event_scheduler=3; | |||
|  | ERROR 42000: Variable 'event_scheduler' can't be set to the value of '3' | |||
|  | set global event_scheduler=disabled; | |||
|  | ERROR 42000: Variable 'event_scheduler' can't be set to the value of 'disabled' | |||
|  | "DISABLE the scheduler. Testing that it does not work when the variable is 0" | |||
|  | set global event_scheduler=off; | |||
|  | select definer, name, db from mysql.event; | |||
|  | definer	name	db | |||
|  | select get_lock("test_lock1", 20); | |||
|  | get_lock("test_lock1", 20) | |||
|  | 1 | |||
|  | create event закачка on schedule every 10 hour do select get_lock("test_lock1", 20); | |||
|  | "Should return 1 row" | |||
|  | select definer, name, db from mysql.event; | |||
|  | definer	name	db | |||
|  | root@localhost	закачка	events_test | |||
|  | "Should be only 0 process" | |||
|  | select /*1*/ user, host, db, command, state, info | |||
|  | from information_schema.processlist | |||
|  | where (user='event_scheduler') | |||
|  | order by info; | |||
|  | user	host	db	command	state	info | |||
|  | select release_lock("test_lock1"); | |||
|  | release_lock("test_lock1") | |||
|  | 1 | |||
|  | drop event закачка; | |||
|  | "Should have 0 events" | |||
|  | select count(*) from mysql.event; | |||
|  | count(*) | |||
|  | 0 | |||
|  | "ENABLE the scheduler and get a lock" | |||
|  | set global event_scheduler=on; | |||
|  | select get_lock("test_lock2", 20); | |||
|  | get_lock("test_lock2", 20) | |||
|  | 1 | |||
|  | "Create an event which tries to acquire a mutex. The event locks on the mutex" | |||
|  | create event закачка on schedule every 10 hour do select get_lock("test_lock2", 20); | |||
|  | "Should have only 2 processes: the scheduler and the locked event" | |||
|  | select /*2*/ user, host, db, command, state, info | |||
|  | from information_schema.processlist | |||
|  | where (info like "select get_lock%" OR user='event_scheduler') | |||
|  | order by info; | |||
|  | user	host	db	command	state	info | |||
|  | event_scheduler	localhost	NULL	Daemon	Waiting for next activation	NULL | |||
|  | root	localhost	events_test	Connect	User lock	select get_lock("test_lock2", 20) | |||
|  | "Release the mutex, the event worker should finish." | |||
|  | select release_lock("test_lock2"); | |||
|  | release_lock("test_lock2") | |||
|  | 1 | |||
|  | drop event закачка; | |||
|  | set global event_scheduler=1; | |||
|  | select get_lock("test_lock2_1", 20); | |||
|  | get_lock("test_lock2_1", 20) | |||
|  | 1 | |||
|  | create event закачка21 on schedule every 10 hour do select get_lock("test_lock2_1", 20); | |||
|  | "Should have only 2 processes: the scheduler and the locked event" | |||
|  | select /*3*/ user, host, db, command, state, info | |||
|  | from information_schema.processlist | |||
|  | where (info like "select get_lock%" OR user='event_scheduler') | |||
|  | order by info; | |||
|  | user	host	db	command	state	info | |||
|  | event_scheduler	localhost	NULL	Daemon	Waiting for next activation	NULL | |||
|  | root	localhost	events_test	Connect	User lock	select get_lock("test_lock2_1", 20) | |||
|  | set global event_scheduler=off; | |||
|  | "Should have only our process now:" | |||
|  | select /*4*/ user, host, db, command, state, info | |||
|  | from information_schema.processlist | |||
|  | where (info like "select get_lock%" OR user='event_scheduler') | |||
|  | order by info; | |||
|  | user	host	db	command	state	info | |||
|  | root	localhost	events_test	Connect	User lock	select get_lock("test_lock2_1", 20) | |||
|  | select release_lock("test_lock2_1"); | |||
|  | release_lock("test_lock2_1") | |||
|  | 1 | |||
|  | drop event закачка21; | |||
|  | create table t_16 (s1 int); | |||
|  | create trigger t_16_bi before insert on t_16 for each row create event  e_16 on schedule every 1 second do set @a=5; | |||
|  | ERROR HY000: Recursion of EVENT DDL statements is forbidden when body is present | |||
|  | drop table t_16; | |||
|  | create event white_space | |||
|  | on schedule every 10 hour | |||
|  | disable | |||
|  | do | |||
|  | select 1; | |||
|  | select event_schema, event_name, definer, event_definition from information_schema.events where event_name='white_space'; | |||
|  | event_schema	event_name	definer	event_definition | |||
|  | events_test	white_space	root@localhost	select 1 | |||
|  | drop event white_space; | |||
|  | create event white_space on schedule every 10 hour disable do | |||
|  | select 2; | |||
|  | select event_schema, event_name, definer, event_definition from information_schema.events where event_name='white_space'; | |||
|  | event_schema	event_name	definer	event_definition | |||
|  | events_test	white_space	root@localhost	select 2 | |||
|  | drop event white_space; | |||
|  | create event white_space on schedule every 10 hour disable do	select 3; | |||
|  | select event_schema, event_name, definer, event_definition from information_schema.events where event_name='white_space'; | |||
|  | event_schema	event_name	definer	event_definition | |||
|  | events_test	white_space	root@localhost	select 3 | |||
|  | drop event white_space; | |||
|  | create event e1 on schedule every 1 year do set @a = 5; | |||
|  | create table t1 (s1 int); | |||
|  | create trigger t1_ai after insert on t1 for each row show create event e1; | |||
|  | ERROR 0A000: Not allowed to return a result set from a trigger | |||
|  | drop table t1; | |||
|  | drop event e1; | |||
|  | SHOW EVENTS FROM aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa; | |||
|  | ERROR 42000: Incorrect database name 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' | |||
|  | SHOW EVENTS FROM ``; | |||
|  | ERROR 42000: Incorrect database name '' | |||
|  | SHOW EVENTS FROM `events\\test`; | |||
|  | Db	Name	Definer	Time zone	Type	Execute at	Interval value	Interval field	Starts	Ends	Status	Originator	character_set_client	collation_connection	Database Collation | |||
|  | 
 | |||
|  | LOCK TABLES mode. | |||
|  | 
 | |||
|  | create table t1 (a int); | |||
|  | create event e1 on schedule every 10 hour do select 1; | |||
|  | lock table t1 read; | |||
|  | show create event e1; | |||
|  | Event	sql_mode	time_zone	Create Event	character_set_client	collation_connection	Database Collation | |||
|  | e1		SYSTEM	CREATE EVENT `e1` ON SCHEDULE EVERY 10 HOUR STARTS '#' ON COMPLETION NOT PRESERVE ENABLE DO select 1	utf8	utf8_general_ci	latin1_swedish_ci | |||
|  | select event_name from information_schema.events; | |||
|  | event_name | |||
|  | e1 | |||
|  | create event e2 on schedule every 10 hour do select 1; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | alter event e2 disable; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | alter event e2 rename to e3; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | drop event e2; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | drop event e1; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | unlock tables; | |||
|  | lock table t1 write; | |||
|  | show create event e1; | |||
|  | Event	sql_mode	time_zone	Create Event	character_set_client	collation_connection	Database Collation | |||
|  | e1		SYSTEM	CREATE EVENT `e1` ON SCHEDULE EVERY 10 HOUR STARTS '#' ON COMPLETION NOT PRESERVE ENABLE DO select 1	utf8	utf8_general_ci	latin1_swedish_ci | |||
|  | select event_name from information_schema.events; | |||
|  | event_name | |||
|  | e1 | |||
|  | create event e2 on schedule every 10 hour do select 1; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | alter event e2 disable; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | alter event e2 rename to e3; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | drop event e2; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | drop event e1; | |||
|  | ERROR HY000: Table 'event' was not locked with LOCK TABLES | |||
|  | unlock tables; | |||
|  | lock table t1 read, mysql.event read; | |||
|  | show create event e1; | |||
|  | Event	sql_mode	time_zone	Create Event	character_set_client	collation_connection	Database Collation | |||
|  | e1		SYSTEM	CREATE EVENT `e1` ON SCHEDULE EVERY 10 HOUR STARTS '#' ON COMPLETION NOT PRESERVE ENABLE DO select 1	utf8	utf8_general_ci	latin1_swedish_ci | |||
|  | select event_name from information_schema.events; | |||
|  | event_name | |||
|  | e1 | |||
|  | create event e2 on schedule every 10 hour do select 1; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | alter event e2 disable; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | alter event e2 rename to e3; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | drop event e2; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | drop event e1; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | unlock tables; | |||
|  | lock table t1 write, mysql.event read; | |||
|  | show create event e1; | |||
|  | Event	sql_mode	time_zone	Create Event	character_set_client	collation_connection	Database Collation | |||
|  | e1		SYSTEM	CREATE EVENT `e1` ON SCHEDULE EVERY 10 HOUR STARTS '#' ON COMPLETION NOT PRESERVE ENABLE DO select 1	utf8	utf8_general_ci	latin1_swedish_ci | |||
|  | select event_name from information_schema.events; | |||
|  | event_name | |||
|  | e1 | |||
|  | create event e2 on schedule every 10 hour do select 1; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | alter event e2 disable; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | alter event e2 rename to e3; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | drop event e2; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | drop event e1; | |||
|  | ERROR HY000: Table 'event' was locked with a READ lock and can't be updated | |||
|  | unlock tables; | |||
|  | lock table t1 read, mysql.event write; | |||
|  | ERROR HY000: You can't combine write-locking of system tables with other tables or lock types | |||
|  | lock table t1 write, mysql.event write; | |||
|  | ERROR HY000: You can't combine write-locking of system tables with other tables or lock types | |||
|  | lock table mysql.event write; | |||
|  | show create event e1; | |||
|  | Event	sql_mode	time_zone	Create Event	character_set_client	collation_connection	Database Collation | |||
|  | e1		SYSTEM	CREATE EVENT `e1` ON SCHEDULE EVERY 10 HOUR STARTS '#' ON COMPLETION NOT PRESERVE ENABLE DO select 1	utf8	utf8_general_ci	latin1_swedish_ci | |||
|  | select event_name from information_schema.events; | |||
|  | event_name | |||
|  | e1 | |||
|  | create event e2 on schedule every 10 hour do select 1; | |||
|  | alter event e2 disable; | |||
|  | alter event e2 rename to e3; | |||
|  | drop event e3; | |||
|  | drop event e1; | |||
|  | unlock tables; | |||
|  | Make sure we have left no events  | |||
|  | select event_name from information_schema.events; | |||
|  | event_name | |||
|  | 
 | |||
|  | Events in sub-statements, events and prelocking | |||
|  | 
 | |||
|  | 
 | |||
|  | create event e1 on schedule every 10 hour do select 1; | |||
|  | create function f1() returns int | |||
|  | begin | |||
|  | show create event e1; | |||
|  | return 1; | |||
|  | end| | |||
|  | ERROR 0A000: Not allowed to return a result set from a function | |||
|  | create trigger trg before insert on t1 for each row | |||
|  | begin | |||
|  | show create event e1; | |||
|  | end| | |||
|  | ERROR 0A000: Not allowed to return a result set from a trigger | |||
|  | create function f1() returns int | |||
|  | begin | |||
|  | select event_name from information_schema.events; | |||
|  | return 1; | |||
|  | end| | |||
|  | ERROR 0A000: Not allowed to return a result set from a function | |||
|  | create trigger trg before insert on t1 for each row | |||
|  | begin | |||
|  | select event_name from information_schema.events; | |||
|  | end| | |||
|  | ERROR 0A000: Not allowed to return a result set from a trigger | |||
|  | create function f1() returns int | |||
|  | begin | |||
|  | create event e2 on schedule every 10 hour do select 1; | |||
|  | return 1; | |||
|  | end| | |||
|  | ERROR HY000: Recursion of EVENT DDL statements is forbidden when body is present | |||
|  | create function f1() returns int | |||
|  | begin | |||
|  | alter event e1 rename to e2; | |||
|  | return 1; | |||
|  | end| | |||
|  | ERROR HY000: Explicit or implicit commit is not allowed in stored function or trigger. | |||
|  | create function f1() returns int | |||
|  | begin | |||
|  | drop event e2; | |||
|  | return 1; | |||
|  | end| | |||
|  | ERROR HY000: Explicit or implicit commit is not allowed in stored function or trigger. | |||
|  | ---------------------------------------------------------------------- | |||
|  | create trigger trg before insert on t1 for each row | |||
|  | begin | |||
|  | set new.a= f1(); | |||
|  | end| | |||
|  | create function f1() returns int | |||
|  | begin | |||
|  | call p1(); | |||
|  | return 0; | |||
|  | end| | |||
|  | create procedure p1() | |||
|  | begin | |||
|  | select event_name from information_schema.events; | |||
|  | end| | |||
|  | insert into t1 (a) values (1)| | |||
|  | ERROR 0A000: Not allowed to return a result set from a trigger | |||
|  | drop procedure p1| | |||
|  | create procedure p1() | |||
|  | begin | |||
|  | show create event e1;  | |||
|  | end| | |||
|  | insert into t1 (a) values (1)| | |||
|  | ERROR 0A000: Not allowed to return a result set from a trigger | |||
|  | drop procedure p1| | |||
|  | create procedure p1() | |||
|  | begin | |||
|  | create temporary table tmp select event_name from information_schema.events; | |||
|  | end| | |||
|  | expected to work, since we redirect the output into a tmp table | |||
|  | insert into t1 (a) values (1)| | |||
|  | select * from tmp| | |||
|  | event_name | |||
|  | e1 | |||
|  | drop temporary table tmp| | |||
|  | drop procedure p1| | |||
|  | create procedure p1() | |||
|  | begin | |||
|  | alter event e1 rename to e2; | |||
|  | end| | |||
|  | insert into t1 (a) values (1)| | |||
|  | ERROR HY000: Explicit or implicit commit is not allowed in stored function or trigger. | |||
|  | drop procedure p1| | |||
|  | create procedure p1() | |||
|  | begin | |||
|  | drop event e1; | |||
|  | end| | |||
|  | insert into t1 (a) values (1)| | |||
|  | ERROR HY000: Explicit or implicit commit is not allowed in stored function or trigger. | |||
|  | drop table t1| | |||
|  | drop event e1| | |||
|  | set names utf8; | |||
|  | create event имя_события_в_кодировке_утф8_длиной_больше_чем_48 on schedule every 2 year do select 1; | |||
|  | select EVENT_NAME from information_schema.events | |||
|  | where event_schema='test'; | |||
|  | EVENT_NAME | |||
|  | drop event имя_события_в_кодировке_утф8_длиной_больше_чем_48; | |||
|  | create event | |||
|  | очень_очень_очень_очень_очень_очень_очень_очень_длинная_строка_66 | |||
|  | on schedule every 2 year do select 1; | |||
|  | ERROR 42000: Identifier name 'очень_очень_очень_очень_очень_очень_очень_очень_длинна' is too long | |||
|  | create event event_35981 on schedule every 6 month on completion preserve | |||
|  | disable | |||
|  | do | |||
|  | select 1; | |||
|  | The following SELECTs should all give 1 | |||
|  | select  count(*) from information_schema.events | |||
|  | where   event_schema = database() and event_name = 'event_35981' and | |||
|  | on_completion = 'PRESERVE'; | |||
|  | count(*) | |||
|  | 1 | |||
|  | alter   event event_35981 enable; | |||
|  | select  count(*) from information_schema.events | |||
|  | where   event_schema = database() and event_name = 'event_35981' and | |||
|  | on_completion = 'PRESERVE'; | |||
|  | count(*) | |||
|  | 1 | |||
|  | alter   event event_35981 on completion not preserve; | |||
|  | select  count(*) from information_schema.events | |||
|  | where   event_schema = database() and event_name = 'event_35981' and | |||
|  | on_completion = 'NOT PRESERVE'; | |||
|  | count(*) | |||
|  | 1 | |||
|  | alter   event event_35981 disable; | |||
|  | select  count(*) from information_schema.events | |||
|  | where   event_schema = database() and event_name = 'event_35981' and | |||
|  | on_completion = 'NOT PRESERVE'; | |||
|  | count(*) | |||
|  | 1 | |||
|  | alter   event event_35981 on completion preserve; | |||
|  | select  count(*) from information_schema.events | |||
|  | where   event_schema = database() and event_name = 'event_35981' and | |||
|  | on_completion = 'PRESERVE'; | |||
|  | count(*) | |||
|  | 1 | |||
|  | drop event event_35981; | |||
|  | create event event_35981 on schedule every 6 month disable | |||
|  | do | |||
|  | select 1; | |||
|  | select  count(*) from information_schema.events | |||
|  | where   event_schema = database() and event_name = 'event_35981' and | |||
|  | on_completion = 'NOT PRESERVE'; | |||
|  | count(*) | |||
|  | 1 | |||
|  | drop event event_35981; | |||
|  | create event event_35981 on schedule every 1 hour starts current_timestamp | |||
|  | on completion not preserve | |||
|  | do | |||
|  | select 1; | |||
|  | alter event event_35981 on schedule every 1 hour starts '1999-01-01 00:00:00' | |||
|  |   ends '1999-01-02 00:00:00'; | |||
|  | ERROR HY000: Event execution time is in the past and ON COMPLETION NOT PRESERVE is set. The event was dropped immediately after creation. | |||
|  | drop event event_35981; | |||
|  | create event event_35981 on schedule every 1 hour starts current_timestamp | |||
|  | on completion not preserve | |||
|  | do | |||
|  | select 1; | |||
|  | alter event event_35981 on schedule every 1 hour starts '1999-01-01 00:00:00' | |||
|  |   ends '1999-01-02 00:00:00' on completion preserve; | |||
|  | Warnings: | |||
|  | Note	1544	Event execution time is in the past. Event has been disabled | |||
|  | drop event event_35981; | |||
|  | create event event_35981 on schedule every 1 hour starts current_timestamp | |||
|  | on completion preserve | |||
|  | do | |||
|  | select 1; | |||
|  | alter event event_35981 on schedule every 1 hour starts '1999-01-01 00:00:00' | |||
|  |   ends '1999-01-02 00:00:00'; | |||
|  | Warnings: | |||
|  | Note	1544	Event execution time is in the past. Event has been disabled | |||
|  | alter event event_35981 on schedule every 1 hour starts '1999-01-01 00:00:00' | |||
|  |   ends '1999-01-02 00:00:00' on completion not preserve; | |||
|  | ERROR HY000: Event execution time is in the past and ON COMPLETION NOT PRESERVE is set. The event was dropped immediately after creation. | |||
|  | alter event event_35981 on schedule every 1 hour starts '1999-01-01 00:00:00' | |||
|  |   ends '1999-01-02 00:00:00' on completion preserve; | |||
|  | Warnings: | |||
|  | Note	1544	Event execution time is in the past. Event has been disabled | |||
|  | drop event event_35981; | |||
|  | drop database events_test; |