305 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
		
		
			
		
	
	
			305 lines
		
	
	
		
			8.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| 
								 | 
							
								set @old_concurrent_insert= @@global.concurrent_insert;
							 | 
						||
| 
								 | 
							
								set @@global.concurrent_insert= 0;
							 | 
						||
| 
								 | 
							
								drop table if exists t1,t3;
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug4902|
							 | 
						||
| 
								 | 
							
								create procedure bug4902()
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								show grants for 'root'@'localhost';
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								call bug4902()|
							 | 
						||
| 
								 | 
							
								Grants for root@localhost
							 | 
						||
| 
								 | 
							
								GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
							 | 
						||
| 
								 | 
							
								call bug4902()|
							 | 
						||
| 
								 | 
							
								Grants for root@localhost
							 | 
						||
| 
								 | 
							
								GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
							 | 
						||
| 
								 | 
							
								drop procedure bug4902|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug4902_2|
							 | 
						||
| 
								 | 
							
								create procedure bug4902_2()
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								show processlist;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								call bug4902_2()|
							 | 
						||
| 
								 | 
							
								show warnings|
							 | 
						||
| 
								 | 
							
								Level	Code	Message
							 | 
						||
| 
								 | 
							
								call bug4902_2()|
							 | 
						||
| 
								 | 
							
								show warnings|
							 | 
						||
| 
								 | 
							
								Level	Code	Message
							 | 
						||
| 
								 | 
							
								drop procedure bug4902_2|
							 | 
						||
| 
								 | 
							
								drop table if exists t1|
							 | 
						||
| 
								 | 
							
								create table t1 (
							 | 
						||
| 
								 | 
							
								id   char(16) not null default '',
							 | 
						||
| 
								 | 
							
								data int not null
							 | 
						||
| 
								 | 
							
								)|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug3583|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug3583|
							 | 
						||
| 
								 | 
							
								create procedure bug3583()
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								declare c int;
							 | 
						||
| 
								 | 
							
								select * from t1;
							 | 
						||
| 
								 | 
							
								select count(*) into c from t1;
							 | 
						||
| 
								 | 
							
								select c;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								insert into t1 values ("x", 3), ("y", 5)|
							 | 
						||
| 
								 | 
							
								set @x = @@query_cache_size|
							 | 
						||
| 
								 | 
							
								set global query_cache_size = 10*1024*1024|
							 | 
						||
| 
								 | 
							
								flush status|
							 | 
						||
| 
								 | 
							
								flush query cache|
							 | 
						||
| 
								 | 
							
								show status like 'Qcache_hits'|
							 | 
						||
| 
								 | 
							
								Variable_name	Value
							 | 
						||
| 
								 | 
							
								Qcache_hits	0
							 | 
						||
| 
								 | 
							
								call bug3583()|
							 | 
						||
| 
								 | 
							
								id	data
							 | 
						||
| 
								 | 
							
								x	3
							 | 
						||
| 
								 | 
							
								y	5
							 | 
						||
| 
								 | 
							
								c
							 | 
						||
| 
								 | 
							
								2
							 | 
						||
| 
								 | 
							
								show status like 'Qcache_hits'|
							 | 
						||
| 
								 | 
							
								Variable_name	Value
							 | 
						||
| 
								 | 
							
								Qcache_hits	0
							 | 
						||
| 
								 | 
							
								call bug3583()|
							 | 
						||
| 
								 | 
							
								id	data
							 | 
						||
| 
								 | 
							
								x	3
							 | 
						||
| 
								 | 
							
								y	5
							 | 
						||
| 
								 | 
							
								c
							 | 
						||
| 
								 | 
							
								2
							 | 
						||
| 
								 | 
							
								call bug3583()|
							 | 
						||
| 
								 | 
							
								id	data
							 | 
						||
| 
								 | 
							
								x	3
							 | 
						||
| 
								 | 
							
								y	5
							 | 
						||
| 
								 | 
							
								c
							 | 
						||
| 
								 | 
							
								2
							 | 
						||
| 
								 | 
							
								show status like 'Qcache_hits'|
							 | 
						||
| 
								 | 
							
								Variable_name	Value
							 | 
						||
| 
								 | 
							
								Qcache_hits	2
							 | 
						||
| 
								 | 
							
								set global query_cache_size = @x|
							 | 
						||
| 
								 | 
							
								flush status|
							 | 
						||
| 
								 | 
							
								flush query cache|
							 | 
						||
| 
								 | 
							
								delete from t1|
							 | 
						||
| 
								 | 
							
								drop procedure bug3583|
							 | 
						||
| 
								 | 
							
								drop table t1|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug6807|
							 | 
						||
| 
								 | 
							
								create procedure bug6807()
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								declare id int;
							 | 
						||
| 
								 | 
							
								set id = connection_id();
							 | 
						||
| 
								 | 
							
								kill query id;
							 | 
						||
| 
								 | 
							
								select 'Not reached';
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								call bug6807()|
							 | 
						||
| 
								 | 
							
								ERROR 70100: Query execution was interrupted
							 | 
						||
| 
								 | 
							
								call bug6807()|
							 | 
						||
| 
								 | 
							
								ERROR 70100: Query execution was interrupted
							 | 
						||
| 
								 | 
							
								drop procedure bug6807|
							 | 
						||
| 
								 | 
							
								drop function if exists bug10100f|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug10100p|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug10100t|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug10100pt|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug10100pv|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug10100pd|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug10100pc|
							 | 
						||
| 
								 | 
							
								create function bug10100f(prm int) returns int
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								if prm > 1 then
							 | 
						||
| 
								 | 
							
								return prm * bug10100f(prm - 1);
							 | 
						||
| 
								 | 
							
								end if;
							 | 
						||
| 
								 | 
							
								return 1;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								create procedure bug10100p(prm int, inout res int)
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								set res = res * prm;
							 | 
						||
| 
								 | 
							
								if prm > 1 then
							 | 
						||
| 
								 | 
							
								call bug10100p(prm - 1, res);
							 | 
						||
| 
								 | 
							
								end if;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								create procedure bug10100t(prm int)
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								declare res int;
							 | 
						||
| 
								 | 
							
								set res = 1;
							 | 
						||
| 
								 | 
							
								call bug10100p(prm, res);
							 | 
						||
| 
								 | 
							
								select res;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								create table t3 (a int)|
							 | 
						||
| 
								 | 
							
								insert into t3 values (0)|
							 | 
						||
| 
								 | 
							
								create view v1 as select a from t3;
							 | 
						||
| 
								 | 
							
								create procedure bug10100pt(level int, lim int)
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								if level < lim then
							 | 
						||
| 
								 | 
							
								update t3 set a=level;
							 | 
						||
| 
								 | 
							
								FLUSH TABLES;
							 | 
						||
| 
								 | 
							
								call bug10100pt(level+1, lim);
							 | 
						||
| 
								 | 
							
								else
							 | 
						||
| 
								 | 
							
								select * from t3;
							 | 
						||
| 
								 | 
							
								end if;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								create procedure bug10100pv(level int, lim int)
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								if level < lim then
							 | 
						||
| 
								 | 
							
								update v1 set a=level;
							 | 
						||
| 
								 | 
							
								FLUSH TABLES;
							 | 
						||
| 
								 | 
							
								call bug10100pv(level+1, lim);
							 | 
						||
| 
								 | 
							
								else
							 | 
						||
| 
								 | 
							
								select * from v1;
							 | 
						||
| 
								 | 
							
								end if;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								prepare stmt2 from "select * from t3;";
							 | 
						||
| 
								 | 
							
								create procedure bug10100pd(level int, lim int)
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								if level < lim then
							 | 
						||
| 
								 | 
							
								select level;
							 | 
						||
| 
								 | 
							
								prepare stmt1 from "update t3 set a=a+2";
							 | 
						||
| 
								 | 
							
								execute stmt1;
							 | 
						||
| 
								 | 
							
								FLUSH TABLES;
							 | 
						||
| 
								 | 
							
								execute stmt1;
							 | 
						||
| 
								 | 
							
								FLUSH TABLES;
							 | 
						||
| 
								 | 
							
								execute stmt1;
							 | 
						||
| 
								 | 
							
								FLUSH TABLES;
							 | 
						||
| 
								 | 
							
								deallocate prepare stmt1;
							 | 
						||
| 
								 | 
							
								execute stmt2;
							 | 
						||
| 
								 | 
							
								select * from t3;
							 | 
						||
| 
								 | 
							
								call bug10100pd(level+1, lim);
							 | 
						||
| 
								 | 
							
								else
							 | 
						||
| 
								 | 
							
								execute stmt2;
							 | 
						||
| 
								 | 
							
								end if;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								create procedure bug10100pc(level int, lim int)
							 | 
						||
| 
								 | 
							
								begin
							 | 
						||
| 
								 | 
							
								declare lv int;
							 | 
						||
| 
								 | 
							
								declare c cursor for select a from t3;
							 | 
						||
| 
								 | 
							
								open c;
							 | 
						||
| 
								 | 
							
								if level < lim then
							 | 
						||
| 
								 | 
							
								select level;
							 | 
						||
| 
								 | 
							
								fetch c into lv;
							 | 
						||
| 
								 | 
							
								select lv;
							 | 
						||
| 
								 | 
							
								update t3 set a=level+lv;
							 | 
						||
| 
								 | 
							
								FLUSH TABLES;
							 | 
						||
| 
								 | 
							
								call bug10100pc(level+1, lim);
							 | 
						||
| 
								 | 
							
								else
							 | 
						||
| 
								 | 
							
								select * from t3;
							 | 
						||
| 
								 | 
							
								end if;
							 | 
						||
| 
								 | 
							
								close c;
							 | 
						||
| 
								 | 
							
								end|
							 | 
						||
| 
								 | 
							
								set @@max_sp_recursion_depth=255|
							 | 
						||
| 
								 | 
							
								set @var=1|
							 | 
						||
| 
								 | 
							
								call bug10100p(255, @var)|
							 | 
						||
| 
								 | 
							
								call bug10100pt(1,255)|
							 | 
						||
| 
								 | 
							
								call bug10100pv(1,255)|
							 | 
						||
| 
								 | 
							
								call bug10100pd(1,255)|
							 | 
						||
| 
								 | 
							
								call bug10100pc(1,255)|
							 | 
						||
| 
								 | 
							
								set @@max_sp_recursion_depth=0|
							 | 
						||
| 
								 | 
							
								deallocate prepare stmt2|
							 | 
						||
| 
								 | 
							
								drop function bug10100f|
							 | 
						||
| 
								 | 
							
								drop procedure bug10100p|
							 | 
						||
| 
								 | 
							
								drop procedure bug10100t|
							 | 
						||
| 
								 | 
							
								drop procedure bug10100pt|
							 | 
						||
| 
								 | 
							
								drop procedure bug10100pv|
							 | 
						||
| 
								 | 
							
								drop procedure bug10100pd|
							 | 
						||
| 
								 | 
							
								drop procedure bug10100pc|
							 | 
						||
| 
								 | 
							
								drop view v1|
							 | 
						||
| 
								 | 
							
								drop table t3|
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug15298_1;
							 | 
						||
| 
								 | 
							
								drop procedure if exists bug15298_2;
							 | 
						||
| 
								 | 
							
								grant all privileges on test.* to 'mysqltest_1'@'localhost';
							 | 
						||
| 
								 | 
							
								create procedure 15298_1 () sql security definer show grants for current_user;
							 | 
						||
| 
								 | 
							
								create procedure 15298_2 () sql security definer show grants;
							 | 
						||
| 
								 | 
							
								call 15298_1();
							 | 
						||
| 
								 | 
							
								Grants for root@localhost
							 | 
						||
| 
								 | 
							
								GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
							 | 
						||
| 
								 | 
							
								call 15298_2();
							 | 
						||
| 
								 | 
							
								Grants for root@localhost
							 | 
						||
| 
								 | 
							
								GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
							 | 
						||
| 
								 | 
							
								drop user mysqltest_1@localhost;
							 | 
						||
| 
								 | 
							
								drop procedure 15298_1;
							 | 
						||
| 
								 | 
							
								drop procedure 15298_2;
							 | 
						||
| 
								 | 
							
								drop table if exists t1;
							 | 
						||
| 
								 | 
							
								drop procedure if exists p1;
							 | 
						||
| 
								 | 
							
								create table t1 (value varchar(15));
							 | 
						||
| 
								 | 
							
								create procedure p1() update t1 set value='updated' where value='old';
							 | 
						||
| 
								 | 
							
								call p1();
							 | 
						||
| 
								 | 
							
								insert into t1 (value) values ("old");
							 | 
						||
| 
								 | 
							
								select get_lock('b26162',120);
							 | 
						||
| 
								 | 
							
								get_lock('b26162',120)
							 | 
						||
| 
								 | 
							
								1
							 | 
						||
| 
								 | 
							
								select 'rl_acquirer', value from t1 where get_lock('b26162',120);;
							 | 
						||
| 
								 | 
							
								set session low_priority_updates=on;
							 | 
						||
| 
								 | 
							
								call p1();;
							 | 
						||
| 
								 | 
							
								select 'rl_contender', value from t1;
							 | 
						||
| 
								 | 
							
								rl_contender	value
							 | 
						||
| 
								 | 
							
								rl_contender	old
							 | 
						||
| 
								 | 
							
								select release_lock('b26162');
							 | 
						||
| 
								 | 
							
								release_lock('b26162')
							 | 
						||
| 
								 | 
							
								1
							 | 
						||
| 
								 | 
							
								rl_acquirer	value
							 | 
						||
| 
								 | 
							
								rl_acquirer	old
							 | 
						||
| 
								 | 
							
								drop procedure p1;
							 | 
						||
| 
								 | 
							
								drop table t1;
							 | 
						||
| 
								 | 
							
								set session low_priority_updates=default;
							 | 
						||
| 
								 | 
							
								INSERT INTO mysql.user (Host, User, Password, Select_priv, Insert_priv, Update_priv,
							 | 
						||
| 
								 | 
							
								Delete_priv, Create_priv, Drop_priv, Reload_priv, Shutdown_priv, Process_priv, File_priv,
							 | 
						||
| 
								 | 
							
								Grant_priv, References_priv, Index_priv, Alter_priv, Show_db_priv, Super_priv,
							 | 
						||
| 
								 | 
							
								Create_tmp_table_priv, Lock_tables_priv, Execute_priv, Repl_slave_priv, Repl_client_priv,
							 | 
						||
| 
								 | 
							
								Create_view_priv, Show_view_priv, Create_routine_priv, Alter_routine_priv,
							 | 
						||
| 
								 | 
							
								Create_user_priv, ssl_type, ssl_cipher, x509_issuer, x509_subject, max_questions,
							 | 
						||
| 
								 | 
							
								max_updates, max_connections, max_user_connections) 
							 | 
						||
| 
								 | 
							
								VALUES('%', 'mysqltest_1', password(''), 'Y', 'Y', 'Y', 'Y', 'Y', 'Y', 'N', 'N', 'N',
							 | 
						||
| 
								 | 
							
								'N', 'N', 'N', 'Y', 'Y', 'N', 'N', 'Y', 'Y', 'N', 'N', 'N', 'N', 'N', 'Y', 'Y', 'N', '',
							 | 
						||
| 
								 | 
							
								'', '', '', '0', '0', '0', '0');
							 | 
						||
| 
								 | 
							
								FLUSH PRIVILEGES;
							 | 
						||
| 
								 | 
							
								CREATE PROCEDURE p1(i INT) BEGIN END;
							 | 
						||
| 
								 | 
							
								DROP PROCEDURE p1;
							 | 
						||
| 
								 | 
							
								DELETE FROM mysql.user WHERE User='mysqltest_1';
							 | 
						||
| 
								 | 
							
								FLUSH PRIVILEGES;
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug#44521 Prepared Statement: CALL p() - crashes: `! thd->main_da.is_sent' failed et.al.
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								SELECT GET_LOCK('Bug44521', 0);
							 | 
						||
| 
								 | 
							
								GET_LOCK('Bug44521', 0)
							 | 
						||
| 
								 | 
							
								1
							 | 
						||
| 
								 | 
							
								** Connection con1
							 | 
						||
| 
								 | 
							
								CREATE PROCEDURE p()
							 | 
						||
| 
								 | 
							
								BEGIN
							 | 
						||
| 
								 | 
							
								SELECT 1;
							 | 
						||
| 
								 | 
							
								SELECT GET_LOCK('Bug44521', 100);
							 | 
						||
| 
								 | 
							
								SELECT 2;
							 | 
						||
| 
								 | 
							
								END$
							 | 
						||
| 
								 | 
							
								CALL p();;
							 | 
						||
| 
								 | 
							
								** Default connection
							 | 
						||
| 
								 | 
							
								SELECT RELEASE_LOCK('Bug44521');
							 | 
						||
| 
								 | 
							
								RELEASE_LOCK('Bug44521')
							 | 
						||
| 
								 | 
							
								1
							 | 
						||
| 
								 | 
							
								DROP PROCEDURE p;
							 | 
						||
| 
								 | 
							
								CREATE TABLE t1(a int);
							 | 
						||
| 
								 | 
							
								INSERT INTO t1 VALUES (1);
							 | 
						||
| 
								 | 
							
								CREATE FUNCTION f1 (inp TEXT) RETURNS INT NO SQL RETURN sleep(60);
							 | 
						||
| 
								 | 
							
								CREATE VIEW v1 AS SELECT f1('a') FROM t1;
							 | 
						||
| 
								 | 
							
								SELECT * FROM v1;;
							 | 
						||
| 
								 | 
							
								SELECT * FROM v1;
							 | 
						||
| 
								 | 
							
								ERROR 70100: Query execution was interrupted
							 | 
						||
| 
								 | 
							
								ERROR 70100: Query execution was interrupted
							 | 
						||
| 
								 | 
							
								DROP VIEW v1;
							 | 
						||
| 
								 | 
							
								DROP TABLE t1;
							 | 
						||
| 
								 | 
							
								DROP FUNCTION f1;
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								# Bug#11763507 - 56224: FUNCTION NAME IS CASE-SENSITIVE
							 | 
						||
| 
								 | 
							
								#
							 | 
						||
| 
								 | 
							
								SET @@SQL_MODE = '';
							 | 
						||
| 
								 | 
							
								CREATE EVENT teste_bug11763507 ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR 
							 | 
						||
| 
								 | 
							
								DO SELECT 1 $
							 | 
						||
| 
								 | 
							
								SHOW EVENTS LIKE 'teste_bug11763507';
							 | 
						||
| 
								 | 
							
								Db	Name	Definer	Time zone	Type	Execute at	Interval value	Interval field	Starts	Ends	Status	Originator	character_set_client	collation_connection	Database Collation
							 | 
						||
| 
								 | 
							
								test	teste_bug11763507	root@localhost	SYSTEM	ONE TIME	#	#	#	#	NULL	ENABLED	1	latin1	latin1_swedish_ci	latin1_swedish_ci
							 | 
						||
| 
								 | 
							
								SHOW EVENTS LIKE 'TESTE_bug11763507';
							 | 
						||
| 
								 | 
							
								Db	Name	Definer	Time zone	Type	Execute at	Interval value	Interval field	Starts	Ends	Status	Originator	character_set_client	collation_connection	Database Collation
							 | 
						||
| 
								 | 
							
								test	teste_bug11763507	root@localhost	SYSTEM	ONE TIME	#	#	#	#	NULL	ENABLED	1	latin1	latin1_swedish_ci	latin1_swedish_ci
							 | 
						||
| 
								 | 
							
								SHOW CREATE EVENT teste_bug11763507;
							 | 
						||
| 
								 | 
							
								Event	sql_mode	time_zone	Create Event	character_set_client	collation_connection	Database Collation
							 | 
						||
| 
								 | 
							
								teste_bug11763507		SYSTEM	#	latin1	latin1_swedish_ci	latin1_swedish_ci
							 | 
						||
| 
								 | 
							
								SHOW CREATE EVENT TESTE_bug11763507;
							 | 
						||
| 
								 | 
							
								Event	sql_mode	time_zone	Create Event	character_set_client	collation_connection	Database Collation
							 | 
						||
| 
								 | 
							
								teste_bug11763507		SYSTEM	#	latin1	latin1_swedish_ci	latin1_swedish_ci
							 | 
						||
| 
								 | 
							
								DROP EVENT teste_bug11763507;
							 | 
						||
| 
								 | 
							
								#END OF BUG#11763507 test.
							 | 
						||
| 
								 | 
							
								# ------------------------------------------------------------------
							 | 
						||
| 
								 | 
							
								# -- End of 5.1 tests
							 | 
						||
| 
								 | 
							
								# ------------------------------------------------------------------
							 | 
						||
| 
								 | 
							
								set @@global.concurrent_insert= @old_concurrent_insert;
							 |