mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 08:28:13 +01:00 
			
		
		
		
	 e7f7789482
			
		
	
	
	e7f7789482
	
	
	
		
			
			* automatically disable ps2 and cursor protocol when the
  select statement returns no result set
* remove manual {disable|enable}_{ps2|cursor}_protocol from around
  `select ... into` in tests
* other misc collateral test cleanups
		
	
			
		
			
				
	
	
		
			8869 lines
		
	
	
	
		
			211 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			8869 lines
		
	
	
	
		
			211 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| set @save_character_set_client=@@character_set_client;
 | ||
| set @save_userstat=@@global.userstat, @@global.userstat= 0;
 | ||
| use test;
 | ||
| create table t1 (
 | ||
| id   char(16) not null default '',
 | ||
| data int not null
 | ||
| );
 | ||
| create table t2 (
 | ||
| s   char(16),
 | ||
| i   int,
 | ||
| d   double
 | ||
| );
 | ||
| create procedure foo42()
 | ||
| insert into test.t1 values ("foo", 42);
 | ||
| call foo42();
 | ||
| select * from t1;
 | ||
| id	data
 | ||
| foo	42
 | ||
| delete from t1;
 | ||
| drop procedure foo42;
 | ||
| create procedure bar(x char(16), y int)
 | ||
| insert into test.t1 values (x, y);
 | ||
| call bar("bar", 666);
 | ||
| select * from t1;
 | ||
| id	data
 | ||
| bar	666
 | ||
| delete from t1;
 | ||
| create procedure empty()
 | ||
| begin
 | ||
| end|
 | ||
| call empty()|
 | ||
| drop procedure empty|
 | ||
| create procedure scope(a int, b float)
 | ||
| begin
 | ||
| declare b int;
 | ||
| declare c float;
 | ||
| begin
 | ||
| declare c int;
 | ||
| end;
 | ||
| end|
 | ||
| drop procedure scope|
 | ||
| create procedure two(x1 char(16), x2 char(16), y int)
 | ||
| begin
 | ||
| insert into test.t1 values (x1, y);
 | ||
| insert into test.t1 values (x2, y);
 | ||
| end|
 | ||
| call two("one", "two", 3)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| one	3
 | ||
| two	3
 | ||
| delete from t1|
 | ||
| drop procedure two|
 | ||
| create procedure locset(x char(16), y int)
 | ||
| begin
 | ||
| declare z1, z2 int;
 | ||
| set z1 = y;
 | ||
| set z2 = z1+2;
 | ||
| insert into test.t1 values (x, z2);
 | ||
| end|
 | ||
| call locset("locset", 19)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| locset	21
 | ||
| delete from t1|
 | ||
| drop procedure locset|
 | ||
| create procedure setcontext()
 | ||
| begin
 | ||
| declare data int default 2;
 | ||
| insert into t1 (id, data) values ("foo", 1);
 | ||
| replace t1 set data = data, id = "bar";
 | ||
| update t1 set id = "kaka", data = 3 where t1.data = data;
 | ||
| end|
 | ||
| call setcontext()|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| foo	1
 | ||
| kaka	3
 | ||
| delete from t1|
 | ||
| drop procedure setcontext|
 | ||
| create table t3 ( d date, i int, f double, s varchar(32) )|
 | ||
| create procedure nullset()
 | ||
| begin
 | ||
| declare ld date;
 | ||
| declare li int;
 | ||
| declare lf double;
 | ||
| declare ls varchar(32);
 | ||
| set ld = null, li = null, lf = null, ls = null;
 | ||
| insert into t3 values (ld, li, lf, ls);
 | ||
| insert into t3 (i, f, s) values ((ld is null), 1,    "ld is null"),
 | ||
| ((li is null), 1,    "li is null"),
 | ||
| ((li = 0),     null, "li = 0"),
 | ||
| ((lf is null), 1,    "lf is null"),
 | ||
| ((lf = 0),     null, "lf = 0"),
 | ||
| ((ls is null), 1,    "ls is null");
 | ||
| end|
 | ||
| call nullset()|
 | ||
| select * from t3|
 | ||
| d	i	f	s
 | ||
| NULL	NULL	NULL	NULL
 | ||
| NULL	1	1	ld is null
 | ||
| NULL	1	1	li is null
 | ||
| NULL	NULL	NULL	li = 0
 | ||
| NULL	1	1	lf is null
 | ||
| NULL	NULL	NULL	lf = 0
 | ||
| NULL	1	1	ls is null
 | ||
| drop table t3|
 | ||
| drop procedure nullset|
 | ||
| create procedure mixset(x char(16), y int)
 | ||
| begin
 | ||
| declare z int;
 | ||
| set @z = y, z = 666, max_join_size = 100;
 | ||
| insert into test.t1 values (x, z);
 | ||
| end|
 | ||
| call mixset("mixset", 19)|
 | ||
| show variables like 'max_join_size'|
 | ||
| Variable_name	Value
 | ||
| max_join_size	100
 | ||
| select id,data,@z from t1|
 | ||
| id	data	@z
 | ||
| mixset	666	19
 | ||
| delete from t1|
 | ||
| drop procedure mixset|
 | ||
| create procedure zip(x char(16), y int)
 | ||
| begin
 | ||
| declare z int;
 | ||
| call zap(y, z);
 | ||
| call bar(x, z);
 | ||
| end|
 | ||
| create procedure zap(x int, out y int)
 | ||
| begin
 | ||
| declare z int;
 | ||
| set z = x+1, y = z;
 | ||
| end|
 | ||
| call zip("zip", 99)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| zip	100
 | ||
| delete from t1|
 | ||
| drop procedure zip|
 | ||
| drop procedure bar|
 | ||
| call zap(7, @zap)|
 | ||
| select @zap|
 | ||
| @zap
 | ||
| 8
 | ||
| drop procedure zap|
 | ||
| create procedure c1(x int)
 | ||
| call c2("c", x)|
 | ||
| create procedure c2(s char(16), x int)
 | ||
| call c3(x, s)|
 | ||
| create procedure c3(x int, s char(16))
 | ||
| call c4("level", x, s)|
 | ||
| create procedure c4(l char(8), x int, s char(16))
 | ||
| insert into t1 values (concat(l,s), x)|
 | ||
| call c1(42)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| levelc	42
 | ||
| delete from t1|
 | ||
| drop procedure c1|
 | ||
| drop procedure c2|
 | ||
| drop procedure c3|
 | ||
| drop procedure c4|
 | ||
| create procedure iotest(x1 char(16), x2 char(16), y int)
 | ||
| begin
 | ||
| call inc2(x2, y);
 | ||
| insert into test.t1 values (x1, y);
 | ||
| end|
 | ||
| create procedure inc2(x char(16), y int)
 | ||
| begin
 | ||
| call inc(y);
 | ||
| insert into test.t1 values (x, y);
 | ||
| end|
 | ||
| create procedure inc(inout io int)
 | ||
| set io = io + 1|
 | ||
| call iotest("io1", "io2", 1)|
 | ||
| select * from t1 order by data desc|
 | ||
| id	data
 | ||
| io2	2
 | ||
| io1	1
 | ||
| delete from t1|
 | ||
| drop procedure iotest|
 | ||
| drop procedure inc2|
 | ||
| create procedure incr(inout x int)
 | ||
| call inc(x)|
 | ||
| select @zap|
 | ||
| @zap
 | ||
| 8
 | ||
| call incr(@zap)|
 | ||
| select @zap|
 | ||
| @zap
 | ||
| 9
 | ||
| drop procedure inc|
 | ||
| drop procedure incr|
 | ||
| create procedure cbv1()
 | ||
| begin
 | ||
| declare y int default 3;
 | ||
| call cbv2(y+1, y);
 | ||
| insert into test.t1 values ("cbv1", y);
 | ||
| end|
 | ||
| create procedure cbv2(y1 int, inout y2 int)
 | ||
| begin
 | ||
| set y2 = 4711;
 | ||
| insert into test.t1 values ("cbv2", y1);
 | ||
| end|
 | ||
| call cbv1()|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| cbv2	4
 | ||
| cbv1	4711
 | ||
| delete from t1|
 | ||
| drop procedure cbv1|
 | ||
| drop procedure cbv2|
 | ||
| insert into t2 values ("a", 1, 1.1), ("b", 2, 1.2), ("c", 3, 1.3)|
 | ||
| create procedure sub1(id char(16), x int)
 | ||
| insert into test.t1 values (id, x)|
 | ||
| create procedure sub2(id char(16))
 | ||
| begin
 | ||
| declare x int;
 | ||
| set x = (select sum(t.i) from test.t2 t);
 | ||
| insert into test.t1 values (id, x);
 | ||
| end|
 | ||
| create function sub3(i int) returns int deterministic
 | ||
| return i+1|
 | ||
| call sub1("sub1a", (select 7))|
 | ||
| call sub1("sub1b", (select max(i) from t2))|
 | ||
| call sub1("sub1c", (select i,d from t2 limit 1))|
 | ||
| ERROR HY000: Cannot cast 'row' as 'int' in assignment of `x`
 | ||
| call sub1("sub1d", (select 1 from (select 1) a))|
 | ||
| call sub2("sub2")|
 | ||
| select * from t1 order by id|
 | ||
| id	data
 | ||
| sub1a	7
 | ||
| sub1b	3
 | ||
| sub1d	1
 | ||
| sub2	6
 | ||
| select sub3((select max(i) from t2))|
 | ||
| sub3((select max(i) from t2))
 | ||
| 4
 | ||
| drop procedure sub1|
 | ||
| drop procedure sub2|
 | ||
| drop function sub3|
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| create procedure a0(x int)
 | ||
| while x do
 | ||
| set x = x-1;
 | ||
| insert into test.t1 values ("a0", x);
 | ||
| end while|
 | ||
| call a0(3)|
 | ||
| select * from t1 order by data desc|
 | ||
| id	data
 | ||
| a0	2
 | ||
| a0	1
 | ||
| a0	0
 | ||
| delete from t1|
 | ||
| drop procedure a0|
 | ||
| create procedure a(x int)
 | ||
| while x > 0 do
 | ||
| set x = x-1;
 | ||
| insert into test.t1 values ("a", x);
 | ||
| end while|
 | ||
| call a(3)|
 | ||
| select * from t1 order by data desc|
 | ||
| id	data
 | ||
| a	2
 | ||
| a	1
 | ||
| a	0
 | ||
| delete from t1|
 | ||
| drop procedure a|
 | ||
| create procedure b(x int)
 | ||
| repeat
 | ||
| insert into test.t1 values (repeat("b",3), x);
 | ||
| set x = x-1;
 | ||
| until x = 0 end repeat|
 | ||
| call b(3)|
 | ||
| select * from t1 order by data desc|
 | ||
| id	data
 | ||
| bbb	3
 | ||
| bbb	2
 | ||
| bbb	1
 | ||
| delete from t1|
 | ||
| drop procedure b|
 | ||
| create procedure b2(x int)
 | ||
| repeat(select 1) into outfile 'b2';
 | ||
| insert into test.t1 values (repeat("b2",3), x);
 | ||
| set x = x-1;
 | ||
| until x = 0 end repeat|
 | ||
| drop procedure b2|
 | ||
| create procedure c(x int)
 | ||
| hmm: while x > 0 do
 | ||
| insert into test.t1 values ("c", x);
 | ||
| set x = x-1;
 | ||
| iterate hmm;
 | ||
| insert into test.t1 values ("x", x);
 | ||
| end while hmm|
 | ||
| call c(3)|
 | ||
| select * from t1 order by data desc|
 | ||
| id	data
 | ||
| c	3
 | ||
| c	2
 | ||
| c	1
 | ||
| delete from t1|
 | ||
| drop procedure c|
 | ||
| create procedure d(x int)
 | ||
| hmm: while x > 0 do
 | ||
| insert into test.t1 values ("d", x);
 | ||
| set x = x-1;
 | ||
| leave hmm;
 | ||
| insert into test.t1 values ("x", x);
 | ||
| end while|
 | ||
| call d(3)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| d	3
 | ||
| delete from t1|
 | ||
| drop procedure d|
 | ||
| create procedure e(x int)
 | ||
| foo: loop
 | ||
| if x = 0 then
 | ||
| leave foo;
 | ||
| end if;
 | ||
| insert into test.t1 values ("e", x);
 | ||
| set x = x-1;
 | ||
| end loop foo|
 | ||
| call e(3)|
 | ||
| select * from t1 order by data desc|
 | ||
| id	data
 | ||
| e	3
 | ||
| e	2
 | ||
| e	1
 | ||
| delete from t1|
 | ||
| drop procedure e|
 | ||
| create procedure f(x int)
 | ||
| if x < 0 then
 | ||
| insert into test.t1 values ("f", 0);
 | ||
| elseif x = 0 then
 | ||
| insert into test.t1 values ("f", 1);
 | ||
| else
 | ||
| insert into test.t1 values ("f", 2);
 | ||
| end if|
 | ||
| call f(-2)|
 | ||
| call f(0)|
 | ||
| call f(4)|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| f	0
 | ||
| f	1
 | ||
| f	2
 | ||
| delete from t1|
 | ||
| drop procedure f|
 | ||
| create procedure g(x int)
 | ||
| case
 | ||
| when x < 0 then
 | ||
| insert into test.t1 values ("g", 0);
 | ||
| when x = 0 then
 | ||
| insert into test.t1 values ("g", 1);
 | ||
| else
 | ||
| insert into test.t1 values ("g", 2);
 | ||
| end case|
 | ||
| call g(-42)|
 | ||
| call g(0)|
 | ||
| call g(1)|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| g	0
 | ||
| g	1
 | ||
| g	2
 | ||
| delete from t1|
 | ||
| drop procedure g|
 | ||
| create procedure h(x int)
 | ||
| case x
 | ||
| when 0 then
 | ||
| insert into test.t1 values ("h0", x);
 | ||
| when 1 then
 | ||
| insert into test.t1 values ("h1", x);
 | ||
| else
 | ||
| insert into test.t1 values ("h?", x);
 | ||
| end case|
 | ||
| call h(0)|
 | ||
| call h(1)|
 | ||
| call h(17)|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| h0	0
 | ||
| h1	1
 | ||
| h?	17
 | ||
| delete from t1|
 | ||
| drop procedure h|
 | ||
| create procedure i(x int)
 | ||
| foo:
 | ||
| begin
 | ||
| if x = 0 then
 | ||
| leave foo;
 | ||
| end if;
 | ||
| insert into test.t1 values ("i", x);
 | ||
| end foo|
 | ||
| call i(0)|
 | ||
| call i(3)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| i	3
 | ||
| delete from t1|
 | ||
| drop procedure i|
 | ||
| insert into t1 values ("foo", 3), ("bar", 19)|
 | ||
| insert into t2 values ("x", 9, 4.1), ("y", -1, 19.2), ("z", 3, 2.2)|
 | ||
| create procedure sel1()
 | ||
| begin
 | ||
| select * from t1 order by data;
 | ||
| end|
 | ||
| call sel1()|
 | ||
| id	data
 | ||
| foo	3
 | ||
| bar	19
 | ||
| drop procedure sel1|
 | ||
| create procedure sel2()
 | ||
| begin
 | ||
| select * from t1 order by data;
 | ||
| select * from t2 order by s;
 | ||
| end|
 | ||
| call sel2()|
 | ||
| id	data
 | ||
| foo	3
 | ||
| bar	19
 | ||
| s	i	d
 | ||
| x	9	4.1
 | ||
| y	-1	19.2
 | ||
| z	3	2.2
 | ||
| drop procedure sel2|
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| create procedure into_test(x char(16), y int)
 | ||
| begin
 | ||
| insert into test.t1 values (x, y);
 | ||
| select id,data into x,y from test.t1 limit 1;
 | ||
| insert into test.t1 values (concat(x, "2"), y+2);
 | ||
| end|
 | ||
| call into_test("into", 100)|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| into	100
 | ||
| into2	102
 | ||
| delete from t1|
 | ||
| drop procedure into_test|
 | ||
| create procedure into_test2(x char(16), y int)
 | ||
| begin
 | ||
| insert into test.t1 values (x, y);
 | ||
| select id,data into x,@z from test.t1 limit 1;
 | ||
| insert into test.t1 values (concat(x, "2"), y+2);
 | ||
| end|
 | ||
| call into_test2("into", 100)|
 | ||
| select id,data,@z from t1 order by data|
 | ||
| id	data	@z
 | ||
| into	100	100
 | ||
| into2	102	100
 | ||
| delete from t1|
 | ||
| drop procedure into_test2|
 | ||
| create procedure into_test3()
 | ||
| begin
 | ||
| declare x char(16);
 | ||
| declare y int;
 | ||
| select * into x,y from test.t1 limit 1;
 | ||
| insert into test.t2 values (x, y, 0.0);
 | ||
| end|
 | ||
| insert into t1 values ("into3", 19)|
 | ||
| call into_test3()|
 | ||
| call into_test3()|
 | ||
| select * from t2|
 | ||
| s	i	d
 | ||
| into3	19	0
 | ||
| into3	19	0
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| drop procedure into_test3|
 | ||
| create procedure into_test4()
 | ||
| begin
 | ||
| declare x int;
 | ||
| select data into x from test.t1 limit 1;
 | ||
| insert into test.t3 values ("into4", x);
 | ||
| end|
 | ||
| delete from t1|
 | ||
| create table t3 ( s char(16), d int)|
 | ||
| call into_test4()|
 | ||
| select * from t3|
 | ||
| s	d
 | ||
| into4	NULL
 | ||
| insert into t1 values ("i4", 77)|
 | ||
| call into_test4()|
 | ||
| select * from t3|
 | ||
| s	d
 | ||
| into4	NULL
 | ||
| into4	77
 | ||
| delete from t1|
 | ||
| drop table t3|
 | ||
| drop procedure into_test4|
 | ||
| create procedure into_outfile(x char(16), y int)
 | ||
| begin
 | ||
| insert into test.t1 values (x, y);
 | ||
| select * into outfile "MYSQLTEST_VARDIR/tmp/spout" from test.t1;
 | ||
| insert into test.t1 values (concat(x, "2"), y+2);
 | ||
| end|
 | ||
| call into_outfile("ofile", 1)|
 | ||
| delete from t1|
 | ||
| drop procedure into_outfile|
 | ||
| create procedure into_dumpfile(x char(16), y int)
 | ||
| begin
 | ||
| insert into test.t1 values (x, y);
 | ||
| select * into dumpfile "MYSQLTEST_VARDIR/tmp/spdump" from test.t1 limit 1;
 | ||
| insert into test.t1 values (concat(x, "2"), y+2);
 | ||
| end|
 | ||
| call into_dumpfile("dfile", 1)|
 | ||
| delete from t1|
 | ||
| drop procedure into_dumpfile|
 | ||
| create procedure create_select(x char(16), y int)
 | ||
| begin
 | ||
| insert into test.t1 values (x, y);
 | ||
| create temporary table test.t3 select * from test.t1;
 | ||
| insert into test.t3 values (concat(x, "2"), y+2);
 | ||
| end|
 | ||
| call create_select("cs", 90)|
 | ||
| select * from t1, t3|
 | ||
| id	data	id	data
 | ||
| cs	90	cs	90
 | ||
| cs	90	cs2	92
 | ||
| drop table t3|
 | ||
| delete from t1|
 | ||
| drop procedure create_select|
 | ||
| create function e() returns double
 | ||
| return 2.7182818284590452354|
 | ||
| set @e = e()|
 | ||
| select e(), @e|
 | ||
| e()	@e
 | ||
| 2.718281828459045	2.718281828459045
 | ||
| create function inc(i int) returns int
 | ||
| return i+1|
 | ||
| select inc(1), inc(99), inc(-71)|
 | ||
| inc(1)	inc(99)	inc(-71)
 | ||
| 2	100	-70
 | ||
| create function mul(x int, y int) returns int
 | ||
| return x*y|
 | ||
| select mul(1,1), mul(3,5), mul(4711, 666)|
 | ||
| mul(1,1)	mul(3,5)	mul(4711, 666)
 | ||
| 1	15	3137526
 | ||
| create function append(s1 char(8), s2 char(8)) returns char(16)
 | ||
| return concat(s1, s2)|
 | ||
| select append("foo", "bar")|
 | ||
| append("foo", "bar")
 | ||
| foobar
 | ||
| create function fac(n int unsigned) returns bigint unsigned
 | ||
| begin
 | ||
| declare f bigint unsigned default 1;
 | ||
| while n > 1 do
 | ||
| set f = f * n;
 | ||
| set n = n - 1;
 | ||
| end while;
 | ||
| return f;
 | ||
| end|
 | ||
| select fac(1), fac(2), fac(5), fac(10)|
 | ||
| fac(1)	fac(2)	fac(5)	fac(10)
 | ||
| 1	2	120	3628800
 | ||
| create function fun(d double, i int, u int unsigned) returns double
 | ||
| return mul(inc(i), fac(u)) / e()|
 | ||
| select fun(2.3, 3, 5)|
 | ||
| fun(2.3, 3, 5)
 | ||
| 176.58213176229233
 | ||
| insert into t2 values (append("xxx", "yyy"), mul(4,3), e())|
 | ||
| insert into t2 values (append("a", "b"), mul(2,mul(3,4)), fun(1.7, 4, 6))|
 | ||
| select * from t2 where s = append("a", "b")|
 | ||
| s	i	d
 | ||
| ab	24	1324.3659882171924
 | ||
| select * from t2 where i = mul(4,3) or i = mul(mul(3,4),2) order by i|
 | ||
| s	i	d
 | ||
| xxxyyy	12	2.718281828459045
 | ||
| ab	24	1324.3659882171924
 | ||
| select * from t2 where d = e()|
 | ||
| s	i	d
 | ||
| xxxyyy	12	2.718281828459045
 | ||
| select * from t2 order by i|
 | ||
| s	i	d
 | ||
| xxxyyy	12	2.718281828459045
 | ||
| ab	24	1324.3659882171924
 | ||
| delete from t2|
 | ||
| drop function e|
 | ||
| drop function inc|
 | ||
| drop function mul|
 | ||
| drop function append|
 | ||
| drop function fun|
 | ||
| create procedure hndlr1(val int)
 | ||
| begin
 | ||
| declare x int default 0;
 | ||
| declare foo condition for 1136;
 | ||
| declare bar condition for sqlstate '42S98';        # Just for testing syntax
 | ||
| declare zip condition for sqlstate value '42S99';  # Just for testing syntax
 | ||
| declare continue handler for foo set x = 1;
 | ||
| insert into test.t1 values ("hndlr1", val, 2);  # Too many values
 | ||
| if (x) then
 | ||
| insert into test.t1 values ("hndlr1", val);   # This instead then
 | ||
| end if;
 | ||
| end|
 | ||
| call hndlr1(42)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| hndlr1	42
 | ||
| delete from t1|
 | ||
| drop procedure hndlr1|
 | ||
| create procedure hndlr2(val int)
 | ||
| begin
 | ||
| declare x int default 0;
 | ||
| begin
 | ||
| declare exit handler for sqlstate '21S01' set x = 1;
 | ||
| insert into test.t1 values ("hndlr2", val, 2); # Too many values
 | ||
| end;
 | ||
| insert into test.t1 values ("hndlr2", x);
 | ||
| end|
 | ||
| call hndlr2(42)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| hndlr2	1
 | ||
| delete from t1|
 | ||
| drop procedure hndlr2|
 | ||
| create procedure hndlr3(val int)
 | ||
| begin
 | ||
| declare x int default 0;
 | ||
| declare continue handler for sqlexception        # Any error
 | ||
| begin
 | ||
| declare z int;
 | ||
| set z = 2 * val;
 | ||
| set x = 1;
 | ||
| end;
 | ||
| if val < 10 then
 | ||
| begin
 | ||
| declare y int;
 | ||
| set y = val + 10;
 | ||
| insert into test.t1 values ("hndlr3", y, 2);  # Too many values
 | ||
| if x then
 | ||
| insert into test.t1 values ("hndlr3", y);
 | ||
| end if;
 | ||
| end;
 | ||
| end if;
 | ||
| end|
 | ||
| call hndlr3(3)|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| hndlr3	13
 | ||
| delete from t1|
 | ||
| drop procedure hndlr3|
 | ||
| create table t3 ( id   char(16), data int )|
 | ||
| create procedure hndlr4()
 | ||
| begin
 | ||
| declare x int default 0;
 | ||
| declare val int;	                           # No default
 | ||
| declare continue handler for sqlstate '02000' set x=1;
 | ||
| select data into val from test.t3 where id='z' limit 1;  # No hits
 | ||
| insert into test.t3 values ('z', val);
 | ||
| end|
 | ||
| call hndlr4()|
 | ||
| select * from t3|
 | ||
| id	data
 | ||
| z	NULL
 | ||
| drop table t3|
 | ||
| drop procedure hndlr4|
 | ||
| create procedure cur1()
 | ||
| begin
 | ||
| declare a char(16);
 | ||
| declare b int;
 | ||
| declare c double;
 | ||
| declare done int default 0;
 | ||
| declare c cursor for select * from test.t2;
 | ||
| declare continue handler for sqlstate '02000' set done = 1;
 | ||
| open c;
 | ||
| repeat
 | ||
| fetch c into a, b, c;
 | ||
| if not done then
 | ||
| insert into test.t1 values (a, b+c);
 | ||
| end if;
 | ||
| until done end repeat;
 | ||
| close c;
 | ||
| end|
 | ||
| insert into t2 values ("foo", 42, -1.9), ("bar", 3, 12.1), ("zap", 666, -3.14)|
 | ||
| call cur1()|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| foo	40
 | ||
| bar	15
 | ||
| zap	663
 | ||
| drop procedure cur1|
 | ||
| create table t3 ( s char(16), i int )|
 | ||
| create procedure cur2()
 | ||
| begin
 | ||
| declare done int default 0;
 | ||
| declare c1 cursor for select id,data from test.t1 order by id,data;
 | ||
| declare c2 cursor for select i from test.t2 order by i;
 | ||
| declare continue handler for sqlstate '02000' set done = 1;
 | ||
| open c1;
 | ||
| open c2;
 | ||
| repeat
 | ||
| begin
 | ||
| declare a char(16);
 | ||
| declare b,c int;
 | ||
| fetch from c1 into a, b;
 | ||
| fetch next from c2 into c;
 | ||
| if not done then
 | ||
| if b < c then
 | ||
| insert into test.t3 values (a, b);
 | ||
| else
 | ||
| insert into test.t3 values (a, c);
 | ||
| end if;
 | ||
| end if;
 | ||
| end;
 | ||
| until done end repeat;
 | ||
| close c1;
 | ||
| close c2;
 | ||
| end|
 | ||
| call cur2()|
 | ||
| select * from t3 order by i,s|
 | ||
| s	i
 | ||
| bar	3
 | ||
| foo	40
 | ||
| zap	663
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| drop table t3|
 | ||
| drop procedure cur2|
 | ||
| create procedure chistics()
 | ||
| language sql
 | ||
| modifies sql data
 | ||
| not deterministic
 | ||
| sql security definer
 | ||
| comment 'Characteristics procedure test'
 | ||
|   insert into t1 values ("chistics", 1)|
 | ||
| show create procedure chistics|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| chistics	STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION	CREATE DEFINER=`root`@`localhost` PROCEDURE `chistics`()
 | ||
|     MODIFIES SQL DATA
 | ||
|     COMMENT 'Characteristics procedure test'
 | ||
| insert into t1 values ("chistics", 1)	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| call chistics()|
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| chistics	1
 | ||
| delete from t1|
 | ||
| alter procedure chistics sql security invoker|
 | ||
| show create procedure chistics|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| chistics	STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION	CREATE DEFINER=`root`@`localhost` PROCEDURE `chistics`()
 | ||
|     MODIFIES SQL DATA
 | ||
|     SQL SECURITY INVOKER
 | ||
|     COMMENT 'Characteristics procedure test'
 | ||
| insert into t1 values ("chistics", 1)	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure chistics|
 | ||
| create function chistics() returns int
 | ||
| language sql
 | ||
| deterministic
 | ||
| sql security invoker
 | ||
| comment 'Characteristics procedure test'
 | ||
|   return 42|
 | ||
| show create function chistics|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| chistics	STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION	CREATE DEFINER=`root`@`localhost` FUNCTION `chistics`() RETURNS int(11)
 | ||
|     DETERMINISTIC
 | ||
|     SQL SECURITY INVOKER
 | ||
|     COMMENT 'Characteristics procedure test'
 | ||
| return 42	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| select chistics()|
 | ||
| chistics()
 | ||
| 42
 | ||
| alter function chistics
 | ||
| no sql
 | ||
| comment 'Characteristics function test'|
 | ||
| show create function chistics|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| chistics	STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION	CREATE DEFINER=`root`@`localhost` FUNCTION `chistics`() RETURNS int(11)
 | ||
|     NO SQL
 | ||
|     DETERMINISTIC
 | ||
|     SQL SECURITY INVOKER
 | ||
|     COMMENT 'Characteristics function test'
 | ||
| return 42	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop function chistics|
 | ||
| insert into t1 values ("foo", 1), ("bar", 2), ("zip", 3)|
 | ||
| set @@sql_mode = 'ANSI'|
 | ||
| create procedure modes(out c1 int, out c2 int)
 | ||
| begin
 | ||
| declare done int default 0;
 | ||
| declare x int;
 | ||
| declare c cursor for select data from t1;
 | ||
| declare continue handler for sqlstate '02000' set done = 1;
 | ||
| select 1 || 2 into c1;
 | ||
| set c2 = 0;
 | ||
| open c;
 | ||
| repeat
 | ||
| fetch c into x;
 | ||
| if not done then
 | ||
| set c2 = c2 + 1;
 | ||
| end if;
 | ||
| until done end repeat;
 | ||
| close c;
 | ||
| end$
 | ||
| set @@sql_mode = ''|
 | ||
| set sql_select_limit = 1|
 | ||
| call modes(@c1, @c2)|
 | ||
| set sql_select_limit = default|
 | ||
| select @c1, @c2|
 | ||
| @c1	@c2
 | ||
| 12	3
 | ||
| delete from t1|
 | ||
| drop procedure modes|
 | ||
| create database sp_db1|
 | ||
| drop database sp_db1|
 | ||
| create database sp_db2|
 | ||
| use sp_db2|
 | ||
| create table t3 ( s char(4), t int )|
 | ||
| insert into t3 values ("abcd", 42), ("dcba", 666)|
 | ||
| use test|
 | ||
| drop database sp_db2|
 | ||
| create database sp_db3|
 | ||
| use sp_db3|
 | ||
| create procedure dummy(out x int)
 | ||
| set x = 42|
 | ||
| use test|
 | ||
| drop database sp_db3|
 | ||
| select type,db,name from mysql.proc where db = 'sp_db3'|
 | ||
| type	db	name
 | ||
| create procedure rc()
 | ||
| begin
 | ||
| delete from t1;
 | ||
| insert into t1 values ("a", 1), ("b", 2), ("c", 3);
 | ||
| end|
 | ||
| call rc()|
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| 3
 | ||
| update t1 set data=42 where id = "b";
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| 1
 | ||
| delete from t1|
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| 3
 | ||
| delete from t1|
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| 0
 | ||
| select * from t1|
 | ||
| id	data
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| -1
 | ||
| drop procedure rc|
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| insert into t1 values ("a", 1), ("b", 2) |
 | ||
| insert into t2 values ("a", 1, 1.0), ("b", 2, 2.0), ("c", 3, 3.0) |
 | ||
| create function f1() returns int
 | ||
| return (select sum(data) from t1)|
 | ||
| select f1()|
 | ||
| f1()
 | ||
| 3
 | ||
| select id, f1() from t1 order by id|
 | ||
| id	f1()
 | ||
| a	3
 | ||
| b	3
 | ||
| create function f2() returns int
 | ||
| return (select data from t1 where data <= (select sum(data) from t1) order by data limit 1)|
 | ||
| select f2()|
 | ||
| f2()
 | ||
| 1
 | ||
| select id, f2() from t1 order by id|
 | ||
| id	f2()
 | ||
| a	1
 | ||
| b	1
 | ||
| create function f3() returns int
 | ||
| begin
 | ||
| declare n int;
 | ||
| declare m int;
 | ||
| set n:= (select min(data) from t1);
 | ||
| set m:= (select max(data) from t1);
 | ||
| return n < m;
 | ||
| end|
 | ||
| select f3()|
 | ||
| f3()
 | ||
| 1
 | ||
| select id, f3() from t1 order by id|
 | ||
| id	f3()
 | ||
| a	1
 | ||
| b	1
 | ||
| select f1(), f3()|
 | ||
| f1()	f3()
 | ||
| 3	1
 | ||
| select id, f1(), f3() from t1 order by id|
 | ||
| id	f1()	f3()
 | ||
| a	3	1
 | ||
| b	3	1
 | ||
| create function f4() returns double 
 | ||
| return (select d from t1, t2 where t1.data = t2.i and t1.id= "b")|
 | ||
| select f4()|
 | ||
| f4()
 | ||
| 2
 | ||
| select s, f4() from t2 order by s|
 | ||
| s	f4()
 | ||
| a	2
 | ||
| b	2
 | ||
| c	2
 | ||
| create function f5(i int) returns int
 | ||
| begin
 | ||
| if i <= 0 then
 | ||
| return 0;
 | ||
| elseif i = 1  then
 | ||
| return (select count(*) from t1 where data = i);
 | ||
| else
 | ||
| return (select count(*) + f5( i - 1) from t1 where data = i);
 | ||
| end if;
 | ||
| end|
 | ||
| select f5(1)|
 | ||
| f5(1)
 | ||
| 1
 | ||
| select f5(2)|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| select f5(3)|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| create function f6() returns int
 | ||
| begin
 | ||
| declare n int;
 | ||
| set n:= f1();
 | ||
| return (select count(*) from t1 where data <= f7() and data <= n);
 | ||
| end|
 | ||
| create function f7() returns int
 | ||
| return (select sum(data) from t1 where data <= f1())|
 | ||
| select f6()|
 | ||
| f6()
 | ||
| 2
 | ||
| select id, f6() from t1 order by id|
 | ||
| id	f6()
 | ||
| a	2
 | ||
| b	2
 | ||
| create view v1 (a) as select f1()|
 | ||
| select * from v1|
 | ||
| a
 | ||
| 3
 | ||
| select id, a from t1, v1 order by id|
 | ||
| id	a
 | ||
| a	3
 | ||
| b	3
 | ||
| select * from v1, v1 as v|
 | ||
| a	a
 | ||
| 3	3
 | ||
| create view v2 (a) as select a*10 from v1|
 | ||
| select * from v2|
 | ||
| a
 | ||
| 30
 | ||
| select id, a from t1, v2 order by id|
 | ||
| id	a
 | ||
| a	30
 | ||
| b	30
 | ||
| select * from v1, v2|
 | ||
| a	a
 | ||
| 3	30
 | ||
| create function f8 () returns int
 | ||
| return (select count(*) from v2)|
 | ||
| select *, f8() from v1|
 | ||
| a	f8()
 | ||
| 3	1
 | ||
| drop function f1|
 | ||
| select * from v1|
 | ||
| ERROR HY000: View 'test.v1' references invalid table(s) or column(s) or function(s) or definer/invoker of view lack rights to use them
 | ||
| create function f1() returns int
 | ||
| return (select sum(data) from t1) + (select sum(data) from v1)|
 | ||
| select f1()|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| select * from v1|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| select * from v2|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| drop function f1|
 | ||
| create function f1() returns int
 | ||
| return (select sum(data) from t1)|
 | ||
| create function f0() returns int
 | ||
| return (select * from (select 100) as r)|
 | ||
| select f0()|
 | ||
| f0()
 | ||
| 100
 | ||
| select *, f0() from (select 1) as t|
 | ||
| 1	f0()
 | ||
| 1	100
 | ||
| create view v0 as select f0()|
 | ||
| select * from v0|
 | ||
| f0()
 | ||
| 100
 | ||
| select *, f0() from v0|
 | ||
| f0()	f0()
 | ||
| 100	100
 | ||
| lock tables t1 read, t1 as t11 read|
 | ||
| select f3()|
 | ||
| f3()
 | ||
| 1
 | ||
| select id, f3() from t1 as t11 order by id|
 | ||
| id	f3()
 | ||
| a	1
 | ||
| b	1
 | ||
| select f0()|
 | ||
| f0()
 | ||
| 100
 | ||
| select * from v0|
 | ||
| ERROR HY000: Table 'v0' was not locked with LOCK TABLES
 | ||
| select *, f0() from v0, (select 123) as d1|
 | ||
| ERROR HY000: Table 'v0' was not locked with LOCK TABLES
 | ||
| select id, f3() from t1|
 | ||
| ERROR HY000: Table 't1' was not locked with LOCK TABLES
 | ||
| select f4()|
 | ||
| ERROR HY000: Table 't2' was not locked with LOCK TABLES
 | ||
| unlock tables|
 | ||
| lock tables v2 read, mysql.proc read|
 | ||
| select * from v2|
 | ||
| a
 | ||
| 30
 | ||
| select * from v1|
 | ||
| a
 | ||
| 3
 | ||
| select * from v1, t1|
 | ||
| ERROR HY000: Table 't1' was not locked with LOCK TABLES
 | ||
| select f4()|
 | ||
| ERROR HY000: Table 't2' was not locked with LOCK TABLES
 | ||
| unlock tables|
 | ||
| create function f9() returns int
 | ||
| begin
 | ||
| declare a, b int;
 | ||
| drop temporary table if exists t3;
 | ||
| create temporary table t3 (id int);
 | ||
| insert into t3 values (1), (2), (3);
 | ||
| set a:= (select count(*) from t3);
 | ||
| set b:= (select count(*) from t3 t3_alias);
 | ||
| return a + b;
 | ||
| end|
 | ||
| select f9()|
 | ||
| f9()
 | ||
| 6
 | ||
| select f9() from t1 limit 1|
 | ||
| f9()
 | ||
| 6
 | ||
| create function f10() returns int
 | ||
| begin
 | ||
| drop temporary table if exists t3;
 | ||
| create temporary table t3 (id int);
 | ||
| insert into t3 select id from t4;
 | ||
| return (select count(*) from t3);
 | ||
| end|
 | ||
| select f10()|
 | ||
| ERROR 42S02: Table 'test.t4' doesn't exist
 | ||
| create table t4 as select 1 as id|
 | ||
| select f10()|
 | ||
| f10()
 | ||
| 1
 | ||
| create function f11() returns int
 | ||
| begin
 | ||
| drop temporary table if exists t3;
 | ||
| create temporary table t3 (id int);
 | ||
| insert into t3 values (1), (2), (3);
 | ||
| return (select count(*) from t3 as a, t3 as b);
 | ||
| end|
 | ||
| select f11()|
 | ||
| f11()
 | ||
| 9
 | ||
| select f11() from t1|
 | ||
| f11()
 | ||
| 9
 | ||
| 9
 | ||
| create function f12_1() returns int
 | ||
| begin
 | ||
| drop temporary table if exists t3;
 | ||
| create temporary table t3 (id int);
 | ||
| insert into t3 values (1), (2), (3);
 | ||
| return f12_2();
 | ||
| end|
 | ||
| create function f12_2() returns int
 | ||
| return (select count(*) from t3)|
 | ||
| drop temporary table t3|
 | ||
| select f12_1()|
 | ||
| f12_1()
 | ||
| 3
 | ||
| drop temporary table t3|
 | ||
| select f12_1() from t1 limit 1|
 | ||
| f12_1()
 | ||
| 3
 | ||
| drop temporary table t3|
 | ||
| drop function f0|
 | ||
| drop function f1|
 | ||
| drop function f2|
 | ||
| drop function f3|
 | ||
| drop function f4|
 | ||
| drop function f5|
 | ||
| drop function f6|
 | ||
| drop function f7|
 | ||
| drop function f8|
 | ||
| drop function f9|
 | ||
| drop function f10|
 | ||
| drop function f11|
 | ||
| drop function f12_1|
 | ||
| drop function f12_2|
 | ||
| drop view v0|
 | ||
| drop view v1|
 | ||
| drop view v2|
 | ||
| truncate table t1 |
 | ||
| truncate table t2 |
 | ||
| drop table t4|
 | ||
| create table t3 (n int unsigned not null primary key, f bigint unsigned)|
 | ||
| create procedure ifac(n int unsigned)
 | ||
| begin
 | ||
| declare i int unsigned default 1;
 | ||
| if n > 20 then
 | ||
| set n = 20;		# bigint overflow otherwise
 | ||
| end if;
 | ||
| while i <= n do
 | ||
| begin
 | ||
| insert into test.t3 values (i, fac(i));
 | ||
| set i = i + 1;
 | ||
| end;
 | ||
| end while;
 | ||
| end|
 | ||
| call ifac(20)|
 | ||
| select * from t3|
 | ||
| n	f
 | ||
| 1	1
 | ||
| 2	2
 | ||
| 3	6
 | ||
| 4	24
 | ||
| 5	120
 | ||
| 6	720
 | ||
| 7	5040
 | ||
| 8	40320
 | ||
| 9	362880
 | ||
| 10	3628800
 | ||
| 11	39916800
 | ||
| 12	479001600
 | ||
| 13	6227020800
 | ||
| 14	87178291200
 | ||
| 15	1307674368000
 | ||
| 16	20922789888000
 | ||
| 17	355687428096000
 | ||
| 18	6402373705728000
 | ||
| 19	121645100408832000
 | ||
| 20	2432902008176640000
 | ||
| drop table t3|
 | ||
| show function status where name like '%f%' and Db <> 'sys'|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| test	fac	FUNCTION	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure ifac|
 | ||
| drop function fac|
 | ||
| show function status where name like '%f%' and Db <> 'sys'|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| create table t3 (
 | ||
| i int unsigned not null primary key,
 | ||
| p bigint unsigned not null
 | ||
| )|
 | ||
| insert into t3 values
 | ||
| ( 0,   3), ( 1,   5), ( 2,   7), ( 3,  11), ( 4,  13),
 | ||
| ( 5,  17), ( 6,  19), ( 7,  23), ( 8,  29), ( 9,  31),
 | ||
| (10,  37), (11,  41), (12,  43), (13,  47), (14,  53),
 | ||
| (15,  59), (16,  61), (17,  67), (18,  71), (19,  73),
 | ||
| (20,  79), (21,  83), (22,  89), (23,  97), (24, 101),
 | ||
| (25, 103), (26, 107), (27, 109), (28, 113), (29, 127),
 | ||
| (30, 131), (31, 137), (32, 139), (33, 149), (34, 151),
 | ||
| (35, 157), (36, 163), (37, 167), (38, 173), (39, 179),
 | ||
| (40, 181), (41, 191), (42, 193), (43, 197), (44, 199)|
 | ||
| create procedure opp(n bigint unsigned, out pp bool)
 | ||
| begin
 | ||
| declare r double;
 | ||
| declare b, s bigint unsigned default 0;
 | ||
| set r = sqrt(n);
 | ||
| again:
 | ||
| loop
 | ||
| if s = 45 then
 | ||
| set b = b+200, s = 0;
 | ||
| else
 | ||
| begin
 | ||
| declare p bigint unsigned;
 | ||
| select t.p into p from test.t3 t where t.i = s;
 | ||
| if b+p > r then
 | ||
| set pp = 1;
 | ||
| leave again;
 | ||
| end if;
 | ||
| if mod(n, b+p) = 0 then
 | ||
| set pp = 0;
 | ||
| leave again;
 | ||
| end if;
 | ||
| set s = s+1;
 | ||
| end;
 | ||
| end if;
 | ||
| end loop;
 | ||
| end|
 | ||
| create procedure ip(m int unsigned)
 | ||
| begin
 | ||
| declare p bigint unsigned;
 | ||
| declare i int unsigned;
 | ||
| set i=45, p=201;
 | ||
| while i < m do
 | ||
| begin
 | ||
| declare pp bool default 0;
 | ||
| call opp(p, pp);
 | ||
| if pp then
 | ||
| insert into test.t3 values (i, p);
 | ||
| set i = i+1;
 | ||
| end if;
 | ||
| set p = p+2;
 | ||
| end;
 | ||
| end while;
 | ||
| end|
 | ||
| show create procedure opp|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| opp		CREATE DEFINER=`root`@`localhost` PROCEDURE `opp`(n bigint unsigned, out pp bool)
 | ||
| begin
 | ||
| declare r double;
 | ||
| declare b, s bigint unsigned default 0;
 | ||
| set r = sqrt(n);
 | ||
| again:
 | ||
| loop
 | ||
| if s = 45 then
 | ||
| set b = b+200, s = 0;
 | ||
| else
 | ||
| begin
 | ||
| declare p bigint unsigned;
 | ||
| select t.p into p from test.t3 t where t.i = s;
 | ||
| if b+p > r then
 | ||
| set pp = 1;
 | ||
| leave again;
 | ||
| end if;
 | ||
| if mod(n, b+p) = 0 then
 | ||
| set pp = 0;
 | ||
| leave again;
 | ||
| end if;
 | ||
| set s = s+1;
 | ||
| end;
 | ||
| end if;
 | ||
| end loop;
 | ||
| end	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| show procedure status where name like '%p%' and db='test'|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| test	ip	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| test	opp	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| call ip(200)|
 | ||
| select * from t3 where i=45 or i=100 or i=199|
 | ||
| i	p
 | ||
| 45	211
 | ||
| 100	557
 | ||
| 199	1229
 | ||
| drop table t3|
 | ||
| drop procedure opp|
 | ||
| drop procedure ip|
 | ||
| show procedure status where name like '%p%' and db='test'|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| create procedure bar(x char(16), y int)
 | ||
| comment "111111111111" sql security invoker
 | ||
| insert into test.t1 values (x, y)|
 | ||
| show procedure status like 'bar'|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| test	bar	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	INVOKER	111111111111	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| alter procedure bar comment "2222222222" sql security definer|
 | ||
| alter procedure bar comment "3333333333"|
 | ||
| alter procedure bar|
 | ||
| show create procedure bar|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bar		CREATE DEFINER=`root`@`localhost` PROCEDURE `bar`(x char(16), y int)
 | ||
|     COMMENT '3333333333'
 | ||
| insert into test.t1 values (x, y)	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| show procedure status like 'bar'|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| test	bar	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER	3333333333	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure bar|
 | ||
| create procedure p1 ()
 | ||
| select (select s1 from t3) from t3|
 | ||
| create table t3 (s1 int)|
 | ||
| call p1()|
 | ||
| (select s1 from t3)
 | ||
| insert into t3 values (1)|
 | ||
| call p1()|
 | ||
| (select s1 from t3)
 | ||
| 1
 | ||
| drop procedure p1|
 | ||
| drop table t3|
 | ||
| create function `foo` () returns int
 | ||
| return 5|
 | ||
| select `foo` ()|
 | ||
| `foo` ()
 | ||
| 5
 | ||
| drop function `foo`|
 | ||
| create function t1max() returns int
 | ||
| begin
 | ||
| declare x int;
 | ||
| select max(data) into x from t1;
 | ||
| return x;
 | ||
| end|
 | ||
| insert into t1 values ("foo", 3), ("bar", 2), ("zip", 5), ("zap", 1)|
 | ||
| select t1max()|
 | ||
| t1max()
 | ||
| 5
 | ||
| drop function t1max|
 | ||
| create table t3 (
 | ||
| v char(16) not null primary key,
 | ||
| c int unsigned not null
 | ||
| )|
 | ||
| create function getcount(s char(16)) returns int
 | ||
| begin
 | ||
| declare x int;
 | ||
| select count(*) into x from t3 where v = s;
 | ||
| if x = 0 then
 | ||
| insert into t3 values (s, 1);
 | ||
| else
 | ||
| update t3 set c = c+1 where v = s;
 | ||
| end if;
 | ||
| return x;
 | ||
| end|
 | ||
| select * from t1 where data = getcount("bar")|
 | ||
| id	data
 | ||
| zap	1
 | ||
| select * from t3|
 | ||
| v	c
 | ||
| bar	4
 | ||
| select getcount("zip")|
 | ||
| getcount("zip")
 | ||
| 0
 | ||
| select getcount("zip")|
 | ||
| getcount("zip")
 | ||
| 1
 | ||
| select * from t3|
 | ||
| v	c
 | ||
| bar	4
 | ||
| zip	2
 | ||
| select getcount(id) from t1 where data = 3|
 | ||
| getcount(id)
 | ||
| 0
 | ||
| select getcount(id) from t1 where data = 5|
 | ||
| getcount(id)
 | ||
| 1
 | ||
| select * from t3|
 | ||
| v	c
 | ||
| bar	4
 | ||
| zip	3
 | ||
| foo	1
 | ||
| drop table t3|
 | ||
| drop function getcount|
 | ||
| create table t3 (a smallint primary key)|
 | ||
| insert into t3 (a) values (1)|
 | ||
| create procedure h_ee()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for 1062 -- ER_DUP_ENTRY
 | ||
| select 'Outer (bad)' as 'h_ee';
 | ||
| begin
 | ||
| declare continue handler for 1062 -- ER_DUP_ENTRY
 | ||
| select 'Inner (good)' as 'h_ee';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_es()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for 1062 -- ER_DUP_ENTRY
 | ||
| select 'Outer (good)' as 'h_es';
 | ||
| begin
 | ||
| -- integrity constraint violation
 | ||
| declare continue handler for sqlstate '23000'
 | ||
|       select 'Inner (bad)' as 'h_es';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_en()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for 1329 -- ER_SP_FETCH_NO_DATA
 | ||
| select 'Outer (good)' as 'h_en';
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare continue handler for sqlstate '02000' -- no data
 | ||
| select 'Inner (bad)' as 'h_en';
 | ||
| select a into x from t3 where a = 42;
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_ew()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for 1264 -- ER_WARN_DATA_OUT_OF_RANGE
 | ||
| select 'Outer (good)' as 'h_ew';
 | ||
| begin
 | ||
| declare continue handler for sqlwarning
 | ||
| select 'Inner (bad)' as 'h_ew';
 | ||
| insert into t3 values (123456789012);
 | ||
| end;
 | ||
| delete from t3;
 | ||
| insert into t3 values (1);
 | ||
| end|
 | ||
| create procedure h_ex()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for 1062 -- ER_DUP_ENTRY
 | ||
| select 'Outer (good)' as 'h_ex';
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| select 'Inner (bad)' as 'h_ex';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_se()
 | ||
| deterministic
 | ||
| begin
 | ||
| -- integrity constraint violation
 | ||
| declare continue handler for sqlstate '23000' 
 | ||
| select 'Outer (bad)' as 'h_se';
 | ||
| begin
 | ||
| declare continue handler for 1062 -- ER_DUP_ENTRY
 | ||
| select 'Inner (good)' as 'h_se';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_ss()
 | ||
| deterministic
 | ||
| begin
 | ||
| -- integrity constraint violation
 | ||
| declare continue handler for sqlstate '23000' 
 | ||
| select 'Outer (bad)' as 'h_ss';
 | ||
| begin
 | ||
| -- integrity constraint violation
 | ||
| declare continue handler for sqlstate '23000' 
 | ||
| select 'Inner (good)' as 'h_ss';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_sn()
 | ||
| deterministic
 | ||
| begin
 | ||
| -- Note: '02000' is more specific than NOT FOUND ;
 | ||
| --       there might be other not found states 
 | ||
| declare continue handler for sqlstate '02000' -- no data
 | ||
| select 'Outer (good)' as 'h_sn';
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare continue handler for not found
 | ||
| select 'Inner (bad)' as 'h_sn';
 | ||
| select a into x from t3 where a = 42;
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_sw()
 | ||
| deterministic
 | ||
| begin
 | ||
| -- data exception - numeric value out of range
 | ||
| declare continue handler for sqlstate '22003'
 | ||
|     select 'Outer (good)' as 'h_sw';
 | ||
| begin
 | ||
| declare continue handler for sqlwarning
 | ||
| select 'Inner (bad)' as 'h_sw';
 | ||
| insert into t3 values (123456789012);
 | ||
| end;
 | ||
| delete from t3;
 | ||
| insert into t3 values (1);
 | ||
| end|
 | ||
| create procedure h_sx()
 | ||
| deterministic
 | ||
| begin
 | ||
| -- integrity constraint violation
 | ||
| declare continue handler for sqlstate '23000' 
 | ||
| select 'Outer (good)' as 'h_sx';
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| select 'Inner (bad)' as 'h_sx';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_ne()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for not found
 | ||
| select 'Outer (bad)' as 'h_ne';
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare continue handler for 1329 -- ER_SP_FETCH_NO_DATA
 | ||
| select 'Inner (good)' as 'h_ne';
 | ||
| select a into x from t3 where a = 42;
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_ns()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for not found
 | ||
| select 'Outer (bad)' as 'h_ns';
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare continue handler for sqlstate '02000' -- no data
 | ||
| select 'Inner (good)' as 'h_ns';
 | ||
| select a into x from t3 where a = 42;
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_nn()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for not found
 | ||
| select 'Outer (bad)' as 'h_nn';
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare continue handler for not found
 | ||
| select 'Inner (good)' as 'h_nn';
 | ||
| select a into x from t3 where a = 42;
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_we()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for sqlwarning
 | ||
| select 'Outer (bad)' as 'h_we';
 | ||
| begin
 | ||
| declare continue handler for 1264 -- ER_WARN_DATA_OUT_OF_RANGE
 | ||
| select 'Inner (good)' as 'h_we';
 | ||
| insert into t3 values (123456789012);
 | ||
| end;
 | ||
| delete from t3;
 | ||
| insert into t3 values (1);
 | ||
| end|
 | ||
| create procedure h_ws()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for sqlwarning
 | ||
| select 'Outer (bad)' as 'h_ws';
 | ||
| begin
 | ||
| -- data exception - numeric value out of range
 | ||
| declare continue handler for sqlstate '22003'
 | ||
|       select 'Inner (good)' as 'h_ws';
 | ||
| insert into t3 values (123456789012);
 | ||
| end;
 | ||
| delete from t3;
 | ||
| insert into t3 values (1);
 | ||
| end|
 | ||
| create procedure h_ww()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for sqlwarning
 | ||
| select 'Outer (bad)' as 'h_ww';
 | ||
| begin
 | ||
| declare continue handler for sqlwarning
 | ||
| select 'Inner (good)' as 'h_ww';
 | ||
| insert into t3 values (123456789012);
 | ||
| end;
 | ||
| delete from t3;
 | ||
| insert into t3 values (1);
 | ||
| end|
 | ||
| create procedure h_xe()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| select 'Outer (bad)' as 'h_xe';
 | ||
| begin
 | ||
| declare continue handler for 1062 -- ER_DUP_ENTRY
 | ||
| select 'Inner (good)' as 'h_xe';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_xs()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| select 'Outer (bad)' as 'h_xs';
 | ||
| begin
 | ||
| -- integrity constraint violation
 | ||
| declare continue handler for sqlstate '23000'
 | ||
|       select 'Inner (good)' as 'h_xs';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure h_xx()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| select 'Outer (bad)' as 'h_xx';
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| select 'Inner (good)' as 'h_xx';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| call h_ee()|
 | ||
| h_ee
 | ||
| Inner (good)
 | ||
| call h_es()|
 | ||
| h_es
 | ||
| Inner (bad)
 | ||
| call h_en()|
 | ||
| h_en
 | ||
| Inner (bad)
 | ||
| call h_ew()|
 | ||
| h_ew
 | ||
| Inner (bad)
 | ||
| call h_ex()|
 | ||
| h_ex
 | ||
| Inner (bad)
 | ||
| call h_se()|
 | ||
| h_se
 | ||
| Inner (good)
 | ||
| call h_ss()|
 | ||
| h_ss
 | ||
| Inner (good)
 | ||
| call h_sn()|
 | ||
| h_sn
 | ||
| Inner (bad)
 | ||
| call h_sw()|
 | ||
| h_sw
 | ||
| Inner (bad)
 | ||
| call h_sx()|
 | ||
| h_sx
 | ||
| Inner (bad)
 | ||
| call h_ne()|
 | ||
| h_ne
 | ||
| Inner (good)
 | ||
| call h_ns()|
 | ||
| h_ns
 | ||
| Inner (good)
 | ||
| call h_nn()|
 | ||
| h_nn
 | ||
| Inner (good)
 | ||
| call h_we()|
 | ||
| h_we
 | ||
| Inner (good)
 | ||
| call h_ws()|
 | ||
| h_ws
 | ||
| Inner (good)
 | ||
| call h_ww()|
 | ||
| h_ww
 | ||
| Inner (good)
 | ||
| call h_xe()|
 | ||
| h_xe
 | ||
| Inner (good)
 | ||
| call h_xs()|
 | ||
| h_xs
 | ||
| Inner (good)
 | ||
| call h_xx()|
 | ||
| h_xx
 | ||
| Inner (good)
 | ||
| drop table t3|
 | ||
| drop procedure h_ee|
 | ||
| drop procedure h_es|
 | ||
| drop procedure h_en|
 | ||
| drop procedure h_ew|
 | ||
| drop procedure h_ex|
 | ||
| drop procedure h_se|
 | ||
| drop procedure h_ss|
 | ||
| drop procedure h_sn|
 | ||
| drop procedure h_sw|
 | ||
| drop procedure h_sx|
 | ||
| drop procedure h_ne|
 | ||
| drop procedure h_ns|
 | ||
| drop procedure h_nn|
 | ||
| drop procedure h_we|
 | ||
| drop procedure h_ws|
 | ||
| drop procedure h_ww|
 | ||
| drop procedure h_xe|
 | ||
| drop procedure h_xs|
 | ||
| drop procedure h_xx|
 | ||
| create procedure bug822(a_id char(16), a_data int)
 | ||
| begin
 | ||
| declare n int;
 | ||
| select count(*) into n from t1 where id = a_id and data = a_data;
 | ||
| if n = 0 then
 | ||
| insert into t1 (id, data) values (a_id, a_data);
 | ||
| end if;
 | ||
| end|
 | ||
| delete from t1|
 | ||
| call bug822('foo', 42)|
 | ||
| call bug822('foo', 42)|
 | ||
| call bug822('bar', 666)|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| foo	42
 | ||
| bar	666
 | ||
| delete from t1|
 | ||
| drop procedure bug822|
 | ||
| create procedure bug1495()
 | ||
| begin
 | ||
| declare x int;
 | ||
| select data into x from t1 order by id limit 1;
 | ||
| if x > 10 then
 | ||
| insert into t1 values ("less", x-10);
 | ||
| else
 | ||
| insert into t1 values ("more", x+10);
 | ||
| end if;
 | ||
| end|
 | ||
| insert into t1 values ('foo', 12)|
 | ||
| call bug1495()|
 | ||
| delete from t1 where id='foo'|
 | ||
| insert into t1 values ('bar', 7)|
 | ||
| call bug1495()|
 | ||
| delete from t1 where id='bar'|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| less	2
 | ||
| more	17
 | ||
| delete from t1|
 | ||
| drop procedure bug1495|
 | ||
| create procedure bug1547(s char(16))
 | ||
| begin
 | ||
| declare x int;
 | ||
| select data into x from t1 where s = id limit 1;
 | ||
| if x > 10 then
 | ||
| insert into t1 values ("less", x-10);
 | ||
| else
 | ||
| insert into t1 values ("more", x+10);
 | ||
| end if;
 | ||
| end|
 | ||
| insert into t1 values ("foo", 12), ("bar", 7)|
 | ||
| call bug1547("foo")|
 | ||
| call bug1547("bar")|
 | ||
| select * from t1 order by id|
 | ||
| id	data
 | ||
| bar	7
 | ||
| foo	12
 | ||
| less	2
 | ||
| more	17
 | ||
| delete from t1|
 | ||
| drop procedure bug1547|
 | ||
| create table t70 (s1 int,s2 int)|
 | ||
| insert into t70 values (1,2)|
 | ||
| create procedure bug1656(out p1 int, out p2 int)
 | ||
| select * into p1, p1 from t70|
 | ||
| call bug1656(@1, @2)|
 | ||
| select @1, @2|
 | ||
| @1	@2
 | ||
| 2	NULL
 | ||
| drop table t70|
 | ||
| drop procedure bug1656|
 | ||
| create table t3(a int)|
 | ||
| create procedure bug1862()
 | ||
| begin
 | ||
| insert into t3 values(2);    
 | ||
| flush tables;
 | ||
| end|
 | ||
| call bug1862()|
 | ||
| call bug1862()|
 | ||
| select * from t3|
 | ||
| a
 | ||
| 2
 | ||
| 2
 | ||
| drop table t3|
 | ||
| drop procedure bug1862|
 | ||
| create procedure bug1874()
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare y double;
 | ||
| select max(data) into x from t1;
 | ||
| insert into t2 values ("max", x, 0);
 | ||
| select min(data) into x from t1;
 | ||
| insert into t2 values ("min", x, 0);
 | ||
| select sum(data) into x from t1;
 | ||
| insert into t2 values ("sum", x, 0);
 | ||
| select avg(data) into y from t1;
 | ||
| insert into t2 values ("avg", 0, y);
 | ||
| end|
 | ||
| insert into t1 (data) values (3), (1), (5), (9), (4)|
 | ||
| call bug1874()|
 | ||
| select * from t2 order by i|
 | ||
| s	i	d
 | ||
| avg	0	4.4
 | ||
| min	1	0
 | ||
| max	9	0
 | ||
| sum	22	0
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| drop procedure bug1874|
 | ||
| create procedure bug2260()
 | ||
| begin
 | ||
| declare v1 int;
 | ||
| declare c1 cursor for select data from t1;
 | ||
| declare continue handler for not found set @x2 = 1;
 | ||
| open c1;
 | ||
| fetch c1 into v1;
 | ||
| set @x2 = 2;
 | ||
| close c1;
 | ||
| end|
 | ||
| call bug2260()|
 | ||
| select @x2|
 | ||
| @x2
 | ||
| 2
 | ||
| drop procedure bug2260|
 | ||
| create procedure bug2267_1()
 | ||
| begin
 | ||
| show procedure status where db='test';
 | ||
| end|
 | ||
| create procedure bug2267_2()
 | ||
| begin
 | ||
| show function status where db='test';
 | ||
| end|
 | ||
| create procedure bug2267_3()
 | ||
| begin
 | ||
| show create procedure bug2267_1;
 | ||
| end|
 | ||
| create procedure bug2267_4()
 | ||
| begin
 | ||
| show create function bug2267_4;
 | ||
| end|
 | ||
| create function bug2267_4() returns int return 100|
 | ||
| call bug2267_1()|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| test	bug2267_1	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| test	bug2267_2	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| test	bug2267_3	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| test	bug2267_4	PROCEDURE	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| call bug2267_2()|
 | ||
| Db	Name	Type	Definer	Modified	Created	Security_type	Comment	character_set_client	collation_connection	Database Collation
 | ||
| test	bug2267_4	FUNCTION	root@localhost	0000-00-00 00:00:00	0000-00-00 00:00:00	DEFINER		latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| call bug2267_3()|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug2267_1		CREATE DEFINER=`root`@`localhost` PROCEDURE `bug2267_1`()
 | ||
| begin
 | ||
| show procedure status where db='test';
 | ||
| end	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| call bug2267_4()|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug2267_4		CREATE DEFINER=`root`@`localhost` FUNCTION `bug2267_4`() RETURNS int(11)
 | ||
| return 100	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure bug2267_1|
 | ||
| drop procedure bug2267_2|
 | ||
| drop procedure bug2267_3|
 | ||
| drop procedure bug2267_4|
 | ||
| drop function bug2267_4|
 | ||
| create procedure bug2227(x int)
 | ||
| begin
 | ||
| declare y float default 2.6;
 | ||
| declare z char(16) default "zzz";
 | ||
| select 1.3, x, y, 42, z;
 | ||
| end|
 | ||
| call bug2227(9)|
 | ||
| 1.3	x	y	42	z
 | ||
| 1.3	9	2.6	42	zzz
 | ||
| drop procedure bug2227|
 | ||
| create procedure bug2614()
 | ||
| begin
 | ||
| drop table if exists t3;
 | ||
| create table t3 (id int default '0' not null);
 | ||
| insert into t3 select 12;
 | ||
| insert into t3 select * from t3;
 | ||
| end|
 | ||
| call bug2614()|
 | ||
| call bug2614()|
 | ||
| drop table t3|
 | ||
| drop procedure bug2614|
 | ||
| create function bug2674() returns int
 | ||
| return @@sort_buffer_size|
 | ||
| set @osbs = @@sort_buffer_size|
 | ||
| set @@sort_buffer_size = 262000|
 | ||
| select bug2674()|
 | ||
| bug2674()
 | ||
| 262000
 | ||
| drop function bug2674|
 | ||
| set @@sort_buffer_size = @osbs|
 | ||
| create procedure bug3259_1 () begin end|
 | ||
| create procedure BUG3259_2 () begin end|
 | ||
| create procedure Bug3259_3 () begin end|
 | ||
| call BUG3259_1()|
 | ||
| call BUG3259_1()|
 | ||
| call bug3259_2()|
 | ||
| call Bug3259_2()|
 | ||
| call bug3259_3()|
 | ||
| call bUG3259_3()|
 | ||
| drop procedure bUg3259_1|
 | ||
| drop procedure BuG3259_2|
 | ||
| drop procedure BUG3259_3|
 | ||
| create function bug2772() returns char(10) character set latin2
 | ||
| return 'a'|
 | ||
| select bug2772()|
 | ||
| bug2772()
 | ||
| a
 | ||
| drop function bug2772|
 | ||
| create procedure bug2776_1(out x int)
 | ||
| begin
 | ||
| declare v int;
 | ||
| set v = default;
 | ||
| set x = v;
 | ||
| end|
 | ||
| create procedure bug2776_2(out x int)
 | ||
| begin
 | ||
| declare v int default 42;
 | ||
| set v = default;
 | ||
| set x = v;
 | ||
| end|
 | ||
| set @x = 1|
 | ||
| call bug2776_1(@x)|
 | ||
| select @x|
 | ||
| @x
 | ||
| NULL
 | ||
| call bug2776_2(@x)|
 | ||
| select @x|
 | ||
| @x
 | ||
| 42
 | ||
| drop procedure bug2776_1|
 | ||
| drop procedure bug2776_2|
 | ||
| create table t3 (s1 smallint)|
 | ||
| insert into t3 values (123456789012)|
 | ||
| Warnings:
 | ||
| Warning	1264	Out of range value for column 's1' at row 1
 | ||
| create procedure bug2780()
 | ||
| begin
 | ||
| declare exit handler for sqlwarning set @x = 1; 
 | ||
| set @x = 0;
 | ||
| insert into t3 values (123456789012);
 | ||
| insert into t3 values (0);
 | ||
| end|
 | ||
| call bug2780()|
 | ||
| select @x|
 | ||
| @x
 | ||
| 1
 | ||
| select * from t3|
 | ||
| s1
 | ||
| 32767
 | ||
| 32767
 | ||
| drop procedure bug2780|
 | ||
| drop table t3|
 | ||
| create table t3 (content varchar(10) )|
 | ||
| insert into t3 values ("test1")|
 | ||
| insert into t3 values ("test2")|
 | ||
| create table t4 (f1 int, rc int, t3 int)|
 | ||
| create procedure bug1863(in1 int)
 | ||
| begin 
 | ||
| declare ind int default 0;
 | ||
| declare t1 int;
 | ||
| declare t2 int;
 | ||
| declare t3 int;
 | ||
| declare rc int default 0;
 | ||
| declare continue handler for 1065 set rc = 1;
 | ||
| drop temporary table if exists temp_t1;
 | ||
| create temporary table temp_t1 (
 | ||
| f1 int auto_increment, f2 varchar(20), primary key (f1)
 | ||
| );
 | ||
| insert into temp_t1 (f2) select content from t3;
 | ||
| select f2 into t3 from temp_t1 where f1 = 10;
 | ||
| if (rc) then
 | ||
| insert into t4 values (1, rc, t3);
 | ||
| end if;
 | ||
| insert into t4 values (2, rc, t3);
 | ||
| end|
 | ||
| call bug1863(10)|
 | ||
| call bug1863(10)|
 | ||
| select * from t4|
 | ||
| f1	rc	t3
 | ||
| 2	0	NULL
 | ||
| 2	0	NULL
 | ||
| drop procedure bug1863|
 | ||
| drop temporary table temp_t1;
 | ||
| drop table t3, t4|
 | ||
| create table t3 ( 
 | ||
| OrderID  int not null,
 | ||
| MarketID int,
 | ||
| primary key (OrderID)
 | ||
| )|
 | ||
| create table t4 ( 
 | ||
| MarketID int not null,
 | ||
| Market varchar(60),
 | ||
| Status char(1),
 | ||
| primary key (MarketID)
 | ||
| )|
 | ||
| insert t3 (OrderID,MarketID) values (1,1)|
 | ||
| insert t3 (OrderID,MarketID) values (2,2)|
 | ||
| insert t4 (MarketID,Market,Status) values (1,"MarketID One","A")|
 | ||
| insert t4 (MarketID,Market,Status) values (2,"MarketID Two","A")|
 | ||
| create procedure bug2656_1()
 | ||
| begin 
 | ||
| select
 | ||
| m.Market
 | ||
| from  t4 m JOIN t3 o 
 | ||
| ON o.MarketID != 1 and o.MarketID = m.MarketID;
 | ||
| end |
 | ||
| create procedure bug2656_2()
 | ||
| begin 
 | ||
| select
 | ||
| m.Market
 | ||
| from  
 | ||
| t4 m, t3 o
 | ||
| where       
 | ||
| m.MarketID != 1 and m.MarketID = o.MarketID;
 | ||
| end |
 | ||
| call bug2656_1()|
 | ||
| Market
 | ||
| MarketID Two
 | ||
| call bug2656_1()|
 | ||
| Market
 | ||
| MarketID Two
 | ||
| call bug2656_2()|
 | ||
| Market
 | ||
| MarketID Two
 | ||
| call bug2656_2()|
 | ||
| Market
 | ||
| MarketID Two
 | ||
| drop procedure bug2656_1|
 | ||
| drop procedure bug2656_2|
 | ||
| drop table t3, t4|
 | ||
| create procedure bug3426(in_time int unsigned, out x int)
 | ||
| begin
 | ||
| if in_time is null then
 | ||
| set @stamped_time=10;
 | ||
| set x=1;
 | ||
| else
 | ||
| set @stamped_time=in_time;
 | ||
| set x=2;
 | ||
| end if;
 | ||
| end|
 | ||
| set time_zone='+03:00';
 | ||
| call bug3426(1000, @i)|
 | ||
| select @i, from_unixtime(@stamped_time, '%d-%m-%Y %h:%i:%s') as time|
 | ||
| @i	time
 | ||
| 2	01-01-1970 03:16:40
 | ||
| call bug3426(NULL, @i)|
 | ||
| select @i, from_unixtime(@stamped_time, '%d-%m-%Y %h:%i:%s') as time|
 | ||
| @i	time
 | ||
| 1	01-01-1970 03:00:10
 | ||
| alter procedure bug3426 sql security invoker|
 | ||
| call bug3426(NULL, @i)|
 | ||
| select @i, from_unixtime(@stamped_time, '%d-%m-%Y %h:%i:%s') as time|
 | ||
| @i	time
 | ||
| 1	01-01-1970 03:00:10
 | ||
| call bug3426(1000, @i)|
 | ||
| select @i, from_unixtime(@stamped_time, '%d-%m-%Y %h:%i:%s') as time|
 | ||
| @i	time
 | ||
| 2	01-01-1970 03:16:40
 | ||
| drop procedure bug3426|
 | ||
| create table t3 (
 | ||
| id int unsigned auto_increment not null primary key,
 | ||
| title VARCHAR(200),
 | ||
| body text,
 | ||
| fulltext (title,body)
 | ||
| )|
 | ||
| insert into t3 (title,body) values
 | ||
| ('MySQL Tutorial','DBMS stands for DataBase ...'),
 | ||
| ('How To Use MySQL Well','After you went through a ...'),
 | ||
| ('Optimizing MySQL','In this tutorial we will show ...'),
 | ||
| ('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),
 | ||
| ('MySQL vs. YourSQL','In the following database comparison ...'),
 | ||
| ('MySQL Security','When configured properly, MySQL ...')|
 | ||
| create procedure bug3734 (param1 varchar(100))
 | ||
| select * from t3 where match (title,body) against (param1)|
 | ||
| call bug3734('database')|
 | ||
| id	title	body
 | ||
| 5	MySQL vs. YourSQL	In the following database comparison ...
 | ||
| 1	MySQL Tutorial	DBMS stands for DataBase ...
 | ||
| call bug3734('Security')|
 | ||
| id	title	body
 | ||
| 6	MySQL Security	When configured properly, MySQL ...
 | ||
| drop procedure bug3734|
 | ||
| drop table t3|
 | ||
| create procedure bug3863()
 | ||
| begin
 | ||
| set @a = 0;
 | ||
| while @a < 5 do
 | ||
| set @a = @a + 1;
 | ||
| end while;
 | ||
| end|
 | ||
| call bug3863()|
 | ||
| select @a|
 | ||
| @a
 | ||
| 5
 | ||
| call bug3863()|
 | ||
| select @a|
 | ||
| @a
 | ||
| 5
 | ||
| drop procedure bug3863|
 | ||
| create table t3 (
 | ||
| id int(10) unsigned not null default 0,
 | ||
| rid int(10) unsigned not null default 0,
 | ||
| msg text not null,
 | ||
| primary key (id),
 | ||
| unique key rid (rid, id)
 | ||
| )|
 | ||
| create procedure bug2460_1(in v int)
 | ||
| begin
 | ||
| ( select n0.id from t3 as n0 where n0.id = v )
 | ||
| union
 | ||
| ( select n0.id from t3 as n0, t3 as n1
 | ||
| where n0.id = n1.rid and n1.id = v )
 | ||
| union
 | ||
| ( select n0.id from t3 as n0, t3 as n1, t3 as n2
 | ||
| where n0.id = n1.rid and n1.id = n2.rid and n2.id = v );
 | ||
| end|
 | ||
| call bug2460_1(2)|
 | ||
| id
 | ||
| call bug2460_1(2)|
 | ||
| id
 | ||
| insert into t3 values (1, 1, 'foo'), (2, 1, 'bar'), (3, 1, 'zip zap')|
 | ||
| call bug2460_1(2)|
 | ||
| id
 | ||
| 2
 | ||
| 1
 | ||
| call bug2460_1(2)|
 | ||
| id
 | ||
| 2
 | ||
| 1
 | ||
| create procedure bug2460_2()
 | ||
| begin
 | ||
| drop table if exists t3;
 | ||
| create temporary table t3 (s1 int);
 | ||
| insert into t3 select 1 union select 1;
 | ||
| end|
 | ||
| call bug2460_2()|
 | ||
| call bug2460_2()|
 | ||
| select * from t3|
 | ||
| s1
 | ||
| 1
 | ||
| drop procedure bug2460_1|
 | ||
| drop procedure bug2460_2|
 | ||
| drop table t3|
 | ||
| set @@sql_mode = ''|
 | ||
| create procedure bug2564_1()
 | ||
| comment 'Joe''s procedure'
 | ||
|   insert into `t1` values ("foo", 1)|
 | ||
| set @@sql_mode = 'ANSI_QUOTES'|
 | ||
| create procedure bug2564_2()
 | ||
| insert into "t1" values ('foo', 1)|
 | ||
| set @@sql_mode = ''$
 | ||
| create function bug2564_3(x int, y int) returns int
 | ||
| return x || y$
 | ||
| set @@sql_mode = 'ANSI'$
 | ||
| create function bug2564_4(x int, y int) returns int
 | ||
| return x || y$
 | ||
| set @@sql_mode = ''|
 | ||
| show create procedure bug2564_1|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug2564_1		CREATE DEFINER=`root`@`localhost` PROCEDURE `bug2564_1`()
 | ||
|     COMMENT 'Joe''s procedure'
 | ||
| insert into `t1` values ("foo", 1)	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| show create procedure bug2564_2|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug2564_2	ANSI_QUOTES	CREATE DEFINER="root"@"localhost" PROCEDURE "bug2564_2"()
 | ||
| insert into "t1" values ('foo', 1)	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| show create function bug2564_3|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug2564_3		CREATE DEFINER=`root`@`localhost` FUNCTION `bug2564_3`(x int, y int) RETURNS int(11)
 | ||
| return x || y	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| show create function bug2564_4|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug2564_4	REAL_AS_FLOAT,PIPES_AS_CONCAT,ANSI_QUOTES,IGNORE_SPACE,ANSI	CREATE DEFINER="root"@"localhost" FUNCTION "bug2564_4"(x int, y int) RETURNS int(11)
 | ||
| return x || y	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure bug2564_1|
 | ||
| drop procedure bug2564_2|
 | ||
| drop function bug2564_3|
 | ||
| drop function bug2564_4|
 | ||
| create function bug3132(s char(20)) returns char(50)
 | ||
| return concat('Hello, ', s, '!')|
 | ||
| select bug3132('Bob') union all select bug3132('Judy')|
 | ||
| bug3132('Bob')
 | ||
| Hello, Bob!
 | ||
| Hello, Judy!
 | ||
| drop function bug3132|
 | ||
| create procedure bug3843()
 | ||
| analyze table t1|
 | ||
| call bug3843()|
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	analyze	status	Engine-independent statistics collected
 | ||
| test.t1	analyze	status	OK
 | ||
| call bug3843()|
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	analyze	status	Engine-independent statistics collected
 | ||
| test.t1	analyze	status	Table is already up to date
 | ||
| select 1+2|
 | ||
| 1+2
 | ||
| 3
 | ||
| drop procedure bug3843|
 | ||
| create table t3 ( s1 char(10) )|
 | ||
| insert into t3 values ('a'), ('b')|
 | ||
| create procedure bug3368(v char(10))
 | ||
| begin
 | ||
| select group_concat(v) from t3;
 | ||
| end|
 | ||
| call bug3368('x')|
 | ||
| group_concat(v)
 | ||
| x,x
 | ||
| call bug3368('yz')|
 | ||
| group_concat(v)
 | ||
| yz,yz
 | ||
| drop procedure bug3368|
 | ||
| drop table t3|
 | ||
| create table t3 (f1 int, f2 int)|
 | ||
| insert into t3 values (1,1)|
 | ||
| create procedure bug4579_1 ()
 | ||
| begin
 | ||
| declare sf1 int;
 | ||
| select f1 into sf1 from t3 where f1=1 and f2=1;
 | ||
| update t3 set f2 = f2 + 1 where f1=1 and f2=1;
 | ||
| call bug4579_2();
 | ||
| end|
 | ||
| create procedure bug4579_2 ()
 | ||
| begin
 | ||
| end|
 | ||
| call bug4579_1()|
 | ||
| call bug4579_1()|
 | ||
| call bug4579_1()|
 | ||
| drop procedure bug4579_1|
 | ||
| drop procedure bug4579_2|
 | ||
| drop table t3|
 | ||
| create function bug2773() returns int return null|
 | ||
| create table t3 as select bug2773()|
 | ||
| show create table t3|
 | ||
| Table	Create Table
 | ||
| t3	CREATE TABLE `t3` (
 | ||
|   `bug2773()` int(11) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| drop table t3|
 | ||
| drop function bug2773|
 | ||
| create function bug3788() returns date return cast("2005-03-04" as date)|
 | ||
| select bug3788()|
 | ||
| bug3788()
 | ||
| 2005-03-04
 | ||
| drop function bug3788|
 | ||
| create function bug3788() returns binary(1) return 5|
 | ||
| select bug3788()|
 | ||
| bug3788()
 | ||
| 5
 | ||
| drop function bug3788|
 | ||
| create table t3 (f1 int, f2 int, f3 int)|
 | ||
| insert into t3 values (1,1,1)|
 | ||
| create procedure bug4726()
 | ||
| begin
 | ||
| declare tmp_o_id INT;
 | ||
| declare tmp_d_id INT default 1;
 | ||
| while tmp_d_id <= 2 do
 | ||
| begin
 | ||
| select f1 into tmp_o_id from t3 where f2=1 and f3=1;
 | ||
| set tmp_d_id = tmp_d_id + 1;
 | ||
| end;
 | ||
| end while;
 | ||
| end|
 | ||
| call bug4726()|
 | ||
| call bug4726()|
 | ||
| call bug4726()|
 | ||
| drop procedure bug4726|
 | ||
| drop table t3|
 | ||
| create procedure bug4902()
 | ||
| begin
 | ||
| show charset like 'foo';
 | ||
| show collation like 'foo';
 | ||
| show create table t1;
 | ||
| show create database test;
 | ||
| show databases like 'foo';
 | ||
| show errors;
 | ||
| show columns from t1;
 | ||
| show keys from t1;
 | ||
| show open tables like 'foo';
 | ||
| # Removed because result will differ in embedded mode.
 | ||
| #show privileges;
 | ||
| show status like 'foo';
 | ||
| show tables like 'foo';
 | ||
| show variables like 'foo';
 | ||
| show warnings;
 | ||
| end|
 | ||
| call bug4902()|
 | ||
| Charset	Description	Default collation	Maxlen
 | ||
| Collation	Charset	Id	Default	Compiled	Sortlen
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `id` char(16) NOT NULL DEFAULT '',
 | ||
|   `data` int(11) NOT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| Database	Create Database
 | ||
| test	CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_uca1400_ai_ci */
 | ||
| Database (foo)
 | ||
| Level	Code	Message
 | ||
| Field	Type	Null	Key	Default	Extra
 | ||
| id	char(16)	NO			
 | ||
| data	int(11)	NO		NULL	
 | ||
| Table	Non_unique	Key_name	Seq_in_index	Column_name	Collation	Cardinality	Sub_part	Packed	Null	Index_type	Comment	Index_comment	Ignored
 | ||
| Database	Table	In_use	Name_locked
 | ||
| Variable_name	Value
 | ||
| Tables_in_test (foo)
 | ||
| Variable_name	Value
 | ||
| Level	Code	Message
 | ||
| call bug4902()|
 | ||
| Charset	Description	Default collation	Maxlen
 | ||
| Collation	Charset	Id	Default	Compiled	Sortlen
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `id` char(16) NOT NULL DEFAULT '',
 | ||
|   `data` int(11) NOT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| Database	Create Database
 | ||
| test	CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_uca1400_ai_ci */
 | ||
| Database (foo)
 | ||
| Level	Code	Message
 | ||
| Field	Type	Null	Key	Default	Extra
 | ||
| id	char(16)	NO			
 | ||
| data	int(11)	NO		NULL	
 | ||
| Table	Non_unique	Key_name	Seq_in_index	Column_name	Collation	Cardinality	Sub_part	Packed	Null	Index_type	Comment	Index_comment	Ignored
 | ||
| Database	Table	In_use	Name_locked
 | ||
| Variable_name	Value
 | ||
| Tables_in_test (foo)
 | ||
| Variable_name	Value
 | ||
| Level	Code	Message
 | ||
| drop procedure bug4902|
 | ||
| create procedure bug4904()
 | ||
| begin
 | ||
| declare continue handler for sqlstate 'HY000' begin end;
 | ||
| create table not_existing_table as select * from t3;
 | ||
| end|
 | ||
| call bug4904()|
 | ||
| ERROR 42S02: Table 'test.t3' doesn't exist
 | ||
| drop procedure bug4904|
 | ||
| create table t3 (s1 char character set latin1, s2 char character set latin2)|
 | ||
| create procedure bug4904 ()
 | ||
| begin
 | ||
| declare continue handler for sqlstate 'HY000' begin end;
 | ||
| select s1 from t3 union select s2 from t3; 
 | ||
| end|
 | ||
| call bug4904()|
 | ||
| drop procedure bug4904|
 | ||
| drop table t3|
 | ||
| create procedure bug336(out y int)
 | ||
| begin
 | ||
| declare x int;
 | ||
| set x = (select sum(t.data) from test.t1 t);
 | ||
| set y = x;
 | ||
| end|
 | ||
| insert into t1 values ("a", 2), ("b", 3)|
 | ||
| call bug336(@y)|
 | ||
| select @y|
 | ||
| @y
 | ||
| 5
 | ||
| delete from t1|
 | ||
| drop procedure bug336|
 | ||
| create procedure bug3157()
 | ||
| begin
 | ||
| if exists(select * from t1) then
 | ||
| set @n= @n + 1;
 | ||
| end if;
 | ||
| if (select count(*) from t1) then
 | ||
| set @n= @n + 1;
 | ||
| end if;
 | ||
| end|
 | ||
| set @n = 0|
 | ||
| insert into t1 values ("a", 1)|
 | ||
| call bug3157()|
 | ||
| select @n|
 | ||
| @n
 | ||
| 2
 | ||
| delete from t1|
 | ||
| drop procedure bug3157|
 | ||
| create procedure bug5251()
 | ||
| begin
 | ||
| end|
 | ||
| select created into @c1 from mysql.proc
 | ||
| where db='test' and name='bug5251'|
 | ||
| alter procedure bug5251 comment 'foobar'|
 | ||
| select count(*) from mysql.proc
 | ||
| where  db='test' and name='bug5251' and created = @c1|
 | ||
| count(*)
 | ||
| 1
 | ||
| drop procedure bug5251|
 | ||
| create procedure bug5251()
 | ||
| checksum table t1|
 | ||
| call bug5251()|
 | ||
| Table	Checksum
 | ||
| test.t1	0
 | ||
| call bug5251()|
 | ||
| Table	Checksum
 | ||
| test.t1	0
 | ||
| drop procedure bug5251|
 | ||
| create procedure bug5287(param1 int)
 | ||
| label1:
 | ||
| begin
 | ||
| declare c cursor for select 5;
 | ||
| loop
 | ||
| if param1 >= 0 then
 | ||
| leave label1;
 | ||
| end if;
 | ||
| end loop;
 | ||
| end|
 | ||
| call bug5287(1)|
 | ||
| drop procedure bug5287|
 | ||
| create procedure bug5307()
 | ||
| begin
 | ||
| end; set @x = 3|
 | ||
| call bug5307()|
 | ||
| select @x|
 | ||
| @x
 | ||
| 3
 | ||
| drop procedure bug5307|
 | ||
| create procedure bug5258()
 | ||
| begin
 | ||
| end|
 | ||
| create procedure bug5258_aux()
 | ||
| begin
 | ||
| declare c, m char(19);
 | ||
| select created,modified into c,m from mysql.proc where name = 'bug5258';
 | ||
| if c = m then
 | ||
| select 'Ok';
 | ||
| else
 | ||
| select c, m;
 | ||
| end if;
 | ||
| end|
 | ||
| call bug5258_aux()|
 | ||
| Ok
 | ||
| Ok
 | ||
| drop procedure bug5258|
 | ||
| drop procedure bug5258_aux|
 | ||
| create function bug4487() returns char
 | ||
| begin
 | ||
| declare v char;
 | ||
| return v;
 | ||
| end|
 | ||
| select bug4487()|
 | ||
| bug4487()
 | ||
| NULL
 | ||
| drop function bug4487|
 | ||
| create procedure bug4941(out x int)
 | ||
| begin
 | ||
| declare c cursor for select i from t2 limit 1;
 | ||
| open c;
 | ||
| fetch c into x;
 | ||
| close c;
 | ||
| end|
 | ||
| insert into t2 values (null, null, null)|
 | ||
| set @x = 42|
 | ||
| call bug4941(@x)|
 | ||
| select @x|
 | ||
| @x
 | ||
| NULL
 | ||
| delete from t1|
 | ||
| drop procedure bug4941|
 | ||
| create table t3 (s1 int,primary key (s1))|
 | ||
| create procedure bug4905()
 | ||
| begin
 | ||
| declare v int;
 | ||
| declare continue handler for sqlstate '23000' set v = 5;
 | ||
| insert into t3 values (1);
 | ||
| end|
 | ||
| call bug4905()|
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| 1
 | ||
| call bug4905()|
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| 0
 | ||
| call bug4905()|
 | ||
| select row_count()|
 | ||
| row_count()
 | ||
| 0
 | ||
| select * from t3|
 | ||
| s1
 | ||
| 1
 | ||
| drop procedure bug4905|
 | ||
| drop table t3|
 | ||
| create procedure bug6029()
 | ||
| begin
 | ||
| declare exit handler for 1136  select '1136';
 | ||
| declare exit handler for sqlstate '23000'  select 'sqlstate 23000';
 | ||
| declare continue handler for sqlexception  select 'sqlexception';
 | ||
| insert into t3 values (1);
 | ||
| insert into t3 values (1,2);
 | ||
| end|
 | ||
| create table t3 (s1 int, primary key (s1))|
 | ||
| insert into t3 values (1)|
 | ||
| call bug6029()|
 | ||
| sqlstate 23000
 | ||
| sqlstate 23000
 | ||
| delete from t3|
 | ||
| call bug6029()|
 | ||
| 1136
 | ||
| 1136
 | ||
| drop procedure bug6029|
 | ||
| drop table t3|
 | ||
| create procedure bug8540()
 | ||
| begin
 | ||
| declare x int default 1;
 | ||
| select x as y, x+0 as z;
 | ||
| end|
 | ||
| call bug8540()|
 | ||
| y	z
 | ||
| 1	1
 | ||
| drop procedure bug8540|
 | ||
| create table t3 (s1 int)|
 | ||
| create procedure bug6642()
 | ||
| select abs(count(s1)) from t3|
 | ||
| call bug6642()|
 | ||
| abs(count(s1))
 | ||
| 0
 | ||
| call bug6642()|
 | ||
| abs(count(s1))
 | ||
| 0
 | ||
| drop procedure bug6642|
 | ||
| insert into t3 values (0),(1)|
 | ||
| create procedure bug7013()
 | ||
| select s1,count(s1) from t3 group by s1 with rollup|
 | ||
| call bug7013()|
 | ||
| s1	count(s1)
 | ||
| 0	1
 | ||
| 1	1
 | ||
| NULL	2
 | ||
| call bug7013()|
 | ||
| s1	count(s1)
 | ||
| 0	1
 | ||
| 1	1
 | ||
| NULL	2
 | ||
| drop procedure bug7013|
 | ||
| create table t4 (
 | ||
| a mediumint(8) unsigned not null auto_increment,
 | ||
| b smallint(5) unsigned not null,
 | ||
| c char(32) not null,
 | ||
| primary key  (a)
 | ||
| ) engine=myisam default charset=latin1|
 | ||
| insert into t4 values (1, 2, 'oneword')|
 | ||
| insert into t4 values (2, 2, 'anotherword')|
 | ||
| create procedure bug7743 ( searchstring char(28) )
 | ||
| begin
 | ||
| declare var mediumint(8) unsigned;
 | ||
| select a into var from t4 where b = 2 and c = binary searchstring limit 1;
 | ||
| select var;
 | ||
| end|
 | ||
| call bug7743("oneword")|
 | ||
| var
 | ||
| 1
 | ||
| call bug7743("OneWord")|
 | ||
| var
 | ||
| NULL
 | ||
| Warnings:
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| call bug7743("anotherword")|
 | ||
| var
 | ||
| 2
 | ||
| call bug7743("AnotherWord")|
 | ||
| var
 | ||
| NULL
 | ||
| Warnings:
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| drop procedure bug7743|
 | ||
| drop table t4|
 | ||
| delete from t3|
 | ||
| insert into t3 values(1)|
 | ||
| create procedure bug7992_1()
 | ||
| begin
 | ||
| declare i int;
 | ||
| select max(s1)+1 into i from t3;
 | ||
| end|
 | ||
| create procedure bug7992_2()
 | ||
| insert into t3 (s1) select max(t4.s1)+1 from t3 as t4|
 | ||
| call bug7992_1()|
 | ||
| call bug7992_1()|
 | ||
| call bug7992_2()|
 | ||
| call bug7992_2()|
 | ||
| drop procedure bug7992_1|
 | ||
| drop procedure bug7992_2|
 | ||
| drop table t3|
 | ||
| create table t3 (  userid bigint(20) not null default 0 )|
 | ||
| create procedure bug8116(in _userid int)
 | ||
| select * from t3 where userid = _userid|
 | ||
| call bug8116(42)|
 | ||
| userid
 | ||
| call bug8116(42)|
 | ||
| userid
 | ||
| drop procedure bug8116|
 | ||
| drop table t3|
 | ||
| create procedure bug6857()
 | ||
| begin
 | ||
| declare t0, t1 bigint;
 | ||
| declare plus bool default 0;
 | ||
| set t0 = unix_timestamp();
 | ||
| select sleep(1.1);
 | ||
| set t1 = unix_timestamp();
 | ||
| if t1 > t0 then
 | ||
| set plus = 1;
 | ||
| end if;
 | ||
| select plus;
 | ||
| end|
 | ||
| call bug6857()|
 | ||
| sleep(1.1)
 | ||
| 0
 | ||
| plus
 | ||
| 1
 | ||
| drop procedure bug6857|
 | ||
| create procedure bug8757()
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare c1 cursor for select data from t1 limit 1;
 | ||
| begin
 | ||
| declare y int;
 | ||
| declare c2 cursor for select i from t2 limit 1;
 | ||
| open c2;
 | ||
| fetch c2 into y;
 | ||
| close c2;
 | ||
| select 2,y;
 | ||
| end;
 | ||
| open c1;
 | ||
| fetch c1 into x;
 | ||
| close c1;
 | ||
| select 1,x;
 | ||
| end|
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| insert into t1 values ("x", 1)|
 | ||
| insert into t2 values ("y", 2, 0.0)|
 | ||
| call bug8757()|
 | ||
| 2	y
 | ||
| 2	2
 | ||
| 1	x
 | ||
| 1	1
 | ||
| delete from t1|
 | ||
| delete from t2|
 | ||
| drop procedure bug8757|
 | ||
| drop procedure if exists bug8762; create procedure bug8762() begin end|
 | ||
| drop procedure if exists bug8762; create procedure bug8762() begin end|
 | ||
| drop procedure bug8762|
 | ||
| create function bug5240 () returns int
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare c cursor for select data from t1 limit 1;
 | ||
| open c;
 | ||
| fetch c into x;
 | ||
| close c;
 | ||
| return x;
 | ||
| end|
 | ||
| delete from t1|
 | ||
| insert into t1 values ("answer", 42)|
 | ||
| select id, bug5240() from t1|
 | ||
| id	bug5240()
 | ||
| answer	42
 | ||
| drop function bug5240|
 | ||
| create table t3(id int)|
 | ||
| insert into t3 values(1)|
 | ||
| create procedure bug7992()
 | ||
| begin
 | ||
| declare i int;
 | ||
| select max(id)+1 into i from t3;
 | ||
| end|
 | ||
| call bug7992()|
 | ||
| call bug7992()|
 | ||
| drop procedure bug7992|
 | ||
| drop table t3|
 | ||
| create table t3 (
 | ||
| lpitnumber int(11) default null,
 | ||
| lrecordtype int(11) default null
 | ||
| )|
 | ||
| create table t4 (
 | ||
| lbsiid int(11) not null default '0',
 | ||
| ltradingmodeid int(11) not null default '0',
 | ||
| ltradingareaid int(11) not null default '0',
 | ||
| csellingprice decimal(19,4) default null,
 | ||
| primary key  (lbsiid,ltradingmodeid,ltradingareaid)
 | ||
| )|
 | ||
| create table t5 (
 | ||
| lbsiid int(11) not null default '0',
 | ||
| ltradingareaid int(11) not null default '0',
 | ||
| primary key  (lbsiid,ltradingareaid)
 | ||
| )|
 | ||
| create procedure bug8849()
 | ||
| begin
 | ||
| insert into t5
 | ||
| (
 | ||
| t5.lbsiid,
 | ||
| t5.ltradingareaid
 | ||
| )
 | ||
| select distinct t3.lpitnumber, t4.ltradingareaid
 | ||
| from
 | ||
| t4 join t3 on
 | ||
| t3.lpitnumber = t4.lbsiid
 | ||
| and t3.lrecordtype = 1
 | ||
| left join t4 as price01 on
 | ||
| price01.lbsiid = t4.lbsiid and
 | ||
| price01.ltradingmodeid = 1 and
 | ||
| t4.ltradingareaid = price01.ltradingareaid;
 | ||
| end|
 | ||
| call bug8849()|
 | ||
| call bug8849()|
 | ||
| call bug8849()|
 | ||
| drop procedure bug8849|
 | ||
| drop tables t3,t4,t5|
 | ||
| create procedure bug8937()
 | ||
| begin
 | ||
| declare s,x,y,z int;
 | ||
| declare a float;
 | ||
| select sum(data),avg(data),min(data),max(data) into s,x,y,z from t1;
 | ||
| select s,x,y,z;
 | ||
| select avg(data) into a from t1;
 | ||
| select a;
 | ||
| end|
 | ||
| delete from t1|
 | ||
| insert into t1 (data) values (1), (2), (3), (4), (6)|
 | ||
| call bug8937()|
 | ||
| s	x	y	z
 | ||
| 16	3	1	6
 | ||
| a
 | ||
| 3.2
 | ||
| drop procedure bug8937|
 | ||
| delete from t1|
 | ||
| create table t3 (w char unique, x char)|
 | ||
| insert into t3 values ('a', 'b')|
 | ||
| create procedure bug6900()
 | ||
| begin
 | ||
| declare exit handler for sqlexception select '1';
 | ||
| begin
 | ||
| declare exit handler for sqlexception select '2';
 | ||
| insert into t3 values ('x', 'y', 'z');
 | ||
| end;
 | ||
| end|
 | ||
| create procedure bug9074()
 | ||
| begin
 | ||
| declare x1, x2, x3, x4, x5, x6 int default 0;
 | ||
| begin    
 | ||
| declare continue handler for sqlstate '23000' set x5 = 1;      
 | ||
| insert into t3 values ('a', 'b');      
 | ||
| set x6 = 1;      
 | ||
| end;
 | ||
| begin1_label:
 | ||
| begin
 | ||
| declare continue handler for sqlstate '23000' set x1 = 1;      
 | ||
| insert into t3 values ('a', 'b');      
 | ||
| set x2 = 1;      
 | ||
| begin2_label:
 | ||
| begin  
 | ||
| declare exit handler for sqlstate '23000' set x3 = 1;         
 | ||
| set x4= 1;         
 | ||
| insert into t3 values ('a','b');
 | ||
| set x4= 0;
 | ||
| end begin2_label;
 | ||
| end begin1_label;
 | ||
| select x1, x2, x3, x4, x5, x6;
 | ||
| end|
 | ||
| create procedure bug6900_9074(z int)
 | ||
| begin
 | ||
| declare exit handler for sqlstate '23000' select '23000';
 | ||
| begin
 | ||
| declare exit handler for sqlexception select 'sqlexception';
 | ||
| if z = 1 then
 | ||
| insert into t3 values ('a', 'b');
 | ||
| else
 | ||
| insert into t3 values ('x', 'y', 'z');
 | ||
| end if;
 | ||
| end;
 | ||
| end|
 | ||
| call bug6900()|
 | ||
| 2
 | ||
| 2
 | ||
| call bug9074()|
 | ||
| x1	x2	x3	x4	x5	x6
 | ||
| 1	1	1	1	1	1
 | ||
| call bug6900_9074(0)|
 | ||
| sqlexception
 | ||
| sqlexception
 | ||
| call bug6900_9074(1)|
 | ||
| sqlexception
 | ||
| sqlexception
 | ||
| drop procedure bug6900|
 | ||
| drop procedure bug9074|
 | ||
| drop procedure bug6900_9074|
 | ||
| drop table t3|
 | ||
| create procedure avg ()
 | ||
| begin
 | ||
| end|
 | ||
| call avg ()|
 | ||
| drop procedure avg|
 | ||
| set @old_mode= @@sql_mode;
 | ||
| set @@sql_mode= "ERROR_FOR_DIVISION_BY_ZERO";
 | ||
| create procedure bug6129()
 | ||
| select @@sql_mode|
 | ||
| call bug6129()|
 | ||
| @@sql_mode
 | ||
| ERROR_FOR_DIVISION_BY_ZERO
 | ||
| set @@sql_mode= "NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO"|
 | ||
| call bug6129()|
 | ||
| @@sql_mode
 | ||
| ERROR_FOR_DIVISION_BY_ZERO
 | ||
| set @@sql_mode= "NO_ZERO_IN_DATE"|
 | ||
| call bug6129()|
 | ||
| @@sql_mode
 | ||
| ERROR_FOR_DIVISION_BY_ZERO
 | ||
| set @@sql_mode=@old_mode;
 | ||
| drop procedure bug6129|
 | ||
| create procedure bug9856()
 | ||
| begin
 | ||
| declare v int;
 | ||
| declare c cursor for select data from t1;
 | ||
| declare exit handler for sqlexception, not found select '16';
 | ||
| open c;
 | ||
| fetch c into v;
 | ||
| select v;
 | ||
| end|
 | ||
| delete from t1|
 | ||
| call bug9856()|
 | ||
| 16
 | ||
| 16
 | ||
| call bug9856()|
 | ||
| 16
 | ||
| 16
 | ||
| drop procedure bug9856|
 | ||
| create procedure bug9674_1(out arg int)
 | ||
| begin
 | ||
| declare temp_in1 int default 0;
 | ||
| declare temp_fl1 int default 0;
 | ||
| set temp_in1 = 100;
 | ||
| set temp_fl1 = temp_in1/10;
 | ||
| set arg = temp_fl1;
 | ||
| end|
 | ||
| create procedure bug9674_2()
 | ||
| begin
 | ||
| declare v int default 100;
 | ||
| select v/10;
 | ||
| end|
 | ||
| call bug9674_1(@sptmp)|
 | ||
| call bug9674_1(@sptmp)|
 | ||
| select @sptmp|
 | ||
| @sptmp
 | ||
| 10
 | ||
| call bug9674_2()|
 | ||
| v/10
 | ||
| 10.0000
 | ||
| call bug9674_2()|
 | ||
| v/10
 | ||
| 10.0000
 | ||
| drop procedure bug9674_1|
 | ||
| drop procedure bug9674_2|
 | ||
| create procedure bug9598_1(in var_1 char(16),
 | ||
| out var_2 integer, out var_3 integer)
 | ||
| begin
 | ||
| set var_2 = 50;
 | ||
| set var_3 = 60;
 | ||
| end|
 | ||
| create procedure bug9598_2(in v1 char(16),
 | ||
| in v2 integer,
 | ||
| in v3 integer,
 | ||
| in v4 integer,
 | ||
| in v5 integer)
 | ||
| begin
 | ||
| select v1,v2,v3,v4,v5;
 | ||
| call bug9598_1(v1,@tmp1,@tmp2);
 | ||
| select v1,v2,v3,v4,v5;
 | ||
| end|
 | ||
| call bug9598_2('Test',2,3,4,5)|
 | ||
| v1	v2	v3	v4	v5
 | ||
| Test	2	3	4	5
 | ||
| v1	v2	v3	v4	v5
 | ||
| Test	2	3	4	5
 | ||
| select @tmp1, @tmp2|
 | ||
| @tmp1	@tmp2
 | ||
| 50	60
 | ||
| drop procedure bug9598_1|
 | ||
| drop procedure bug9598_2|
 | ||
| create function bug9902() returns int(11)
 | ||
| begin
 | ||
| set @x = @x + 1;
 | ||
| return @x;
 | ||
| end|
 | ||
| # Set query cache size, if we have query cache
 | ||
| set @x = 1|
 | ||
| insert into t1 values ("qc", 42)|
 | ||
| select bug9902() from t1|
 | ||
| bug9902()
 | ||
| 2
 | ||
| select bug9902() from t1|
 | ||
| bug9902()
 | ||
| 3
 | ||
| select @x|
 | ||
| @x
 | ||
| 3
 | ||
| # Restore the old query cache size
 | ||
| delete from t1|
 | ||
| drop function bug9902|
 | ||
| create function bug9102() returns blob return 'a'|
 | ||
| select bug9102()|
 | ||
| bug9102()
 | ||
| a
 | ||
| drop function bug9102|
 | ||
| create function bug7648() returns bit(8) return 'a'|
 | ||
| select bug7648()|
 | ||
| bug7648()
 | ||
| a
 | ||
| drop function bug7648|
 | ||
| create function bug9775(v1 char(1)) returns enum('a','b') return v1|
 | ||
| select bug9775('a'),bug9775('b'),bug9775('c')|
 | ||
| bug9775('a')	bug9775('b')	bug9775('c')
 | ||
| a	b	
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'bug9775('c')' at row 0
 | ||
| drop function bug9775|
 | ||
| create function bug9775(v1 int) returns enum('a','b') return v1|
 | ||
| select bug9775(1),bug9775(2),bug9775(3)|
 | ||
| bug9775(1)	bug9775(2)	bug9775(3)
 | ||
| a	b	
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'bug9775(3)' at row 0
 | ||
| drop function bug9775|
 | ||
| create function bug9775(v1 char(1)) returns set('a','b') return v1|
 | ||
| select bug9775('a'),bug9775('b'),bug9775('a,b'),bug9775('c')|
 | ||
| bug9775('a')	bug9775('b')	bug9775('a,b')	bug9775('c')
 | ||
| a	b	a	
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'v1' at row 1
 | ||
| Warning	1265	Data truncated for column 'bug9775('c')' at row 0
 | ||
| drop function bug9775|
 | ||
| create function bug9775(v1 int) returns set('a','b') return v1|
 | ||
| select bug9775(1),bug9775(2),bug9775(3),bug9775(4)|
 | ||
| bug9775(1)	bug9775(2)	bug9775(3)	bug9775(4)
 | ||
| a	b	a,b	
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'bug9775(4)' at row 0
 | ||
| drop function bug9775|
 | ||
| create function bug8861(v1 int) returns year return v1|
 | ||
| select bug8861(05)|
 | ||
| bug8861(05)
 | ||
| 2005
 | ||
| set @x = bug8861(05)|
 | ||
| select @x|
 | ||
| @x
 | ||
| 2005
 | ||
| drop function bug8861|
 | ||
| create procedure bug9004_1(x char(16))
 | ||
| begin
 | ||
| insert into t1 values (x, 42);
 | ||
| insert into t1 values (x, 17);
 | ||
| end|
 | ||
| create procedure bug9004_2(x char(16))
 | ||
| call bug9004_1(x)|
 | ||
| call bug9004_1('12345678901234567')|
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'x' at row 0
 | ||
| call bug9004_2('12345678901234567890')|
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'x' at row 0
 | ||
| delete from t1|
 | ||
| drop procedure bug9004_1|
 | ||
| drop procedure bug9004_2|
 | ||
| insert into t1 values ('secret', 0)|
 | ||
| create procedure bug7293(p1 varchar(100))
 | ||
| begin
 | ||
| if exists (select id from t1 where soundex(p1)=soundex(id)) then
 | ||
| select 'yes';
 | ||
| end if;
 | ||
| end;|
 | ||
| call bug7293('secret')|
 | ||
| yes
 | ||
| yes
 | ||
| call bug7293 ('secrete')|
 | ||
| yes
 | ||
| yes
 | ||
| drop procedure bug7293|
 | ||
| delete from t1|
 | ||
| create view v1 as select * from t1, t2 where id = s|
 | ||
| create procedure bug9841 ()
 | ||
| update v1 set data = 10|
 | ||
| call bug9841()|
 | ||
| drop view v1|
 | ||
| drop procedure bug9841|
 | ||
| create procedure bug5963_1 () begin declare v int; set v = (select s1 from t3); select v; end;|
 | ||
| create table t3 (s1 int)|
 | ||
| insert into t3 values (5)|
 | ||
| call bug5963_1()|
 | ||
| v
 | ||
| 5
 | ||
| call bug5963_1()|
 | ||
| v
 | ||
| 5
 | ||
| drop procedure bug5963_1|
 | ||
| drop table t3|
 | ||
| create procedure bug5963_2 (cfk_value int) 
 | ||
| begin 
 | ||
| if cfk_value in (select cpk from t3) then 
 | ||
| set @x = 5; 
 | ||
| end if; 
 | ||
| end; 
 | ||
| |
 | ||
| create table t3 (cpk int)|
 | ||
| insert into t3 values (1)|
 | ||
| call bug5963_2(1)|
 | ||
| call bug5963_2(1)|
 | ||
| drop procedure bug5963_2|
 | ||
| drop table t3|
 | ||
| create function bug9559()
 | ||
| returns int
 | ||
| begin
 | ||
| set @y = -6/2;
 | ||
| return @y;
 | ||
| end|
 | ||
| select bug9559()|
 | ||
| bug9559()
 | ||
| -3
 | ||
| drop function bug9559|
 | ||
| create procedure bug10961()
 | ||
| begin
 | ||
| declare v char;
 | ||
| declare x int;
 | ||
| declare c cursor for select * from dual;
 | ||
| declare continue handler for sqlexception select x;
 | ||
| set x = 1;
 | ||
| open c;
 | ||
| set x = 2;
 | ||
| fetch c into v;
 | ||
| set x = 3;
 | ||
| close c;
 | ||
| end|
 | ||
| call bug10961()|
 | ||
| x
 | ||
| 1
 | ||
| x
 | ||
| 2
 | ||
| x
 | ||
| 3
 | ||
| call bug10961()|
 | ||
| x
 | ||
| 1
 | ||
| x
 | ||
| 2
 | ||
| x
 | ||
| 3
 | ||
| drop procedure bug10961|
 | ||
| CREATE TABLE tt1 (a1 int, a2 int, a3 int, data varchar(10))|
 | ||
| CREATE TABLE tt2 (a2 int, data2 varchar(10))|
 | ||
| CREATE TABLE tt3 (a3 int, data3 varchar(10))|
 | ||
| INSERT INTO tt1 VALUES (1, 1, 4, 'xx')|
 | ||
| INSERT INTO tt2 VALUES (1, 'a')|
 | ||
| INSERT INTO tt2 VALUES (2, 'b')|
 | ||
| INSERT INTO tt2 VALUES (3, 'c')|
 | ||
| INSERT INTO tt3 VALUES (4, 'd')|
 | ||
| INSERT INTO tt3 VALUES (5, 'e')|
 | ||
| INSERT INTO tt3 VALUES (6, 'f')|
 | ||
| CREATE VIEW tv AS
 | ||
| SELECT tt1.*, tt2.data2, tt3.data3
 | ||
| FROM tt1 INNER JOIN tt2 ON tt1.a2 = tt2.a2
 | ||
| LEFT JOIN tt3 ON tt1.a3 = tt3.a3
 | ||
| ORDER BY tt1.a1, tt2.a2, tt3.a3|
 | ||
| CREATE PROCEDURE bug6866 (_a1 int)
 | ||
| BEGIN
 | ||
| SELECT * FROM tv WHERE a1 = _a1;
 | ||
| END|
 | ||
| CALL bug6866(1)|
 | ||
| a1	a2	a3	data	data2	data3
 | ||
| 1	1	4	xx	a	d
 | ||
| CALL bug6866(1)|
 | ||
| a1	a2	a3	data	data2	data3
 | ||
| 1	1	4	xx	a	d
 | ||
| CALL bug6866(1)|
 | ||
| a1	a2	a3	data	data2	data3
 | ||
| 1	1	4	xx	a	d
 | ||
| DROP PROCEDURE bug6866;
 | ||
| DROP VIEW tv|
 | ||
| DROP TABLE tt1, tt2, tt3|
 | ||
| create table t3 ( name char(5) not null primary key, val float not null)|
 | ||
| insert into t3 values ('aaaaa', 1), ('bbbbb', 2), ('ccccc', 3)|
 | ||
| create procedure bug10136()
 | ||
| begin
 | ||
| declare done int default 3;
 | ||
| repeat
 | ||
| select * from t3;
 | ||
| set done = done - 1;
 | ||
| until done <= 0 end repeat;
 | ||
| end|
 | ||
| call bug10136()|
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| call bug10136()|
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| call bug10136()|
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| name	val
 | ||
| aaaaa	1
 | ||
| bbbbb	2
 | ||
| ccccc	3
 | ||
| drop procedure bug10136|
 | ||
| drop table t3|
 | ||
| create procedure bug11529()
 | ||
| begin
 | ||
| declare c cursor for select id, data from t1 where data in (10,13);
 | ||
| open c;
 | ||
| begin
 | ||
| declare vid char(16);
 | ||
| declare vdata int;
 | ||
| declare exit handler for not found begin end;
 | ||
| while true do
 | ||
| fetch c into vid, vdata;
 | ||
| end while;
 | ||
| end;
 | ||
| close c;
 | ||
| end|
 | ||
| insert into t1 values
 | ||
| ('Name1', 10),
 | ||
| ('Name2', 11),
 | ||
| ('Name3', 12),
 | ||
| ('Name4', 13),
 | ||
| ('Name5', 14)|
 | ||
| call bug11529()|
 | ||
| call bug11529()|
 | ||
| delete from t1|
 | ||
| drop procedure bug11529|
 | ||
| set character set utf8|
 | ||
| create procedure bug6063()
 | ||
| begin
 | ||
| lâbel: begin end;
 | ||
| label: begin end;
 | ||
| label1: begin end;
 | ||
| end|
 | ||
| create procedure bug7088_1()
 | ||
| label1: begin end label1|
 | ||
| create procedure bug7088_2()
 | ||
| läbel1: begin end|
 | ||
| call bug6063()|
 | ||
| call bug7088_1()|
 | ||
| call bug7088_2()|
 | ||
| set @@character_set_client=@save_character_set_client|
 | ||
| set @@character_set_results=@save_character_set_client|
 | ||
| show create procedure bug6063|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug6063		CREATE DEFINER=`root`@`localhost` PROCEDURE `bug6063`()
 | ||
| begin
 | ||
| l<EFBFBD>bel: begin end;
 | ||
| label: begin end;
 | ||
| label1: begin end;
 | ||
| end	utf8mb3	utf8mb4_uca1400_ai_ci	utf8mb4_uca1400_ai_ci
 | ||
| show create procedure bug7088_1|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug7088_1		CREATE DEFINER=`root`@`localhost` PROCEDURE `bug7088_1`()
 | ||
| label1: begin end label1	utf8mb3	utf8mb4_uca1400_ai_ci	utf8mb4_uca1400_ai_ci
 | ||
| show create procedure bug7088_2|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug7088_2		CREATE DEFINER=`root`@`localhost` PROCEDURE `bug7088_2`()
 | ||
| l<EFBFBD>bel1: begin end	utf8mb3	utf8mb4_uca1400_ai_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure bug6063|
 | ||
| drop procedure bug7088_1|
 | ||
| drop procedure bug7088_2|
 | ||
| create procedure bug9565_sub()
 | ||
| begin
 | ||
| select * from t1;
 | ||
| end|
 | ||
| create procedure bug9565()
 | ||
| begin
 | ||
| insert into t1 values ("one", 1);
 | ||
| call bug9565_sub();
 | ||
| end|
 | ||
| call bug9565()|
 | ||
| id	data
 | ||
| one	1
 | ||
| delete from t1|
 | ||
| drop procedure bug9565_sub|
 | ||
| drop procedure bug9565|
 | ||
| create procedure bug9538()
 | ||
| set @@sort_buffer_size = 1000000|
 | ||
| set @x = @@sort_buffer_size|
 | ||
| set @@sort_buffer_size = 2000000|
 | ||
| select @@sort_buffer_size|
 | ||
| @@sort_buffer_size
 | ||
| 2000000
 | ||
| call bug9538()|
 | ||
| select @@sort_buffer_size|
 | ||
| @@sort_buffer_size
 | ||
| 1000000
 | ||
| set @@sort_buffer_size = @x|
 | ||
| drop procedure bug9538|
 | ||
| create table t3 (c1 varchar(5), c2 char(5), c3 enum('one','two'), c4 text, c5 blob, c6 char(5), c7 varchar(5))|
 | ||
| insert into t3 values ('', '', '', '', '', '', NULL)|
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'c3' at row 1
 | ||
| create procedure bug8692()
 | ||
| begin 
 | ||
| declare v1 VARCHAR(10); 
 | ||
| declare v2 VARCHAR(10); 
 | ||
| declare v3 VARCHAR(10); 
 | ||
| declare v4 VARCHAR(10); 
 | ||
| declare v5 VARCHAR(10); 
 | ||
| declare v6 VARCHAR(10); 
 | ||
| declare v7 VARCHAR(10); 
 | ||
| declare c8692 cursor for select c1,c2,c3,c4,c5,c6,c7 from t3; 
 | ||
| open c8692; 
 | ||
| fetch c8692 into v1,v2,v3,v4,v5,v6,v7;
 | ||
| select v1, v2, v3, v4, v5, v6, v7;
 | ||
| end|
 | ||
| call bug8692()|
 | ||
| v1	v2	v3	v4	v5	v6	v7
 | ||
| 						NULL
 | ||
| drop procedure bug8692|
 | ||
| drop table t3|
 | ||
| create function bug10055(v char(255)) returns char(255) return lower(v)|
 | ||
| select t.column_name, bug10055(t.column_name)
 | ||
| from information_schema.columns as t
 | ||
| where t.table_schema = 'test' and t.table_name = 't1'|
 | ||
| column_name	bug10055(t.column_name)
 | ||
| id	id
 | ||
| data	data
 | ||
| drop function bug10055|
 | ||
| create procedure bug12297(lim int)
 | ||
| begin
 | ||
| set @x = 0;
 | ||
| repeat
 | ||
| insert into t1(id,data)
 | ||
| values('aa', @x);
 | ||
| set @x = @x + 1;
 | ||
| until @x >= lim
 | ||
| end repeat;
 | ||
| end|
 | ||
| call bug12297(10)|
 | ||
| drop procedure bug12297|
 | ||
| create function f_bug11247(param int)
 | ||
| returns int
 | ||
| return param + 1|
 | ||
| create procedure p_bug11247(lim int)
 | ||
| begin
 | ||
| declare v int default 0;
 | ||
| while v < lim do
 | ||
| set v= f_bug11247(v);
 | ||
| end while;
 | ||
| end|
 | ||
| call p_bug11247(10)|
 | ||
| drop function f_bug11247|
 | ||
| drop procedure p_bug11247|
 | ||
| create table t3 (a int)|
 | ||
| insert into t3 values (1),(2),(3),(4)|
 | ||
| create table t4 (a int)|
 | ||
| create procedure bug12168(arg1 char(1))
 | ||
| begin
 | ||
| declare b, c integer;
 | ||
| if arg1 = 'a' then
 | ||
| begin
 | ||
| declare c1 cursor for select a from t3 where a % 2;
 | ||
| declare continue handler for not found set b = 1;
 | ||
| set b = 0;
 | ||
| open c1;
 | ||
| c1_repeat: repeat
 | ||
| fetch c1 into c;
 | ||
| if (b = 1) then
 | ||
| leave c1_repeat;
 | ||
| end if;
 | ||
| insert into t4 values (c);
 | ||
| until b = 1
 | ||
| end repeat;
 | ||
| end;
 | ||
| end if;
 | ||
| if arg1 = 'b' then
 | ||
| begin
 | ||
| declare c2 cursor for select a from t3 where not a % 2;
 | ||
| declare continue handler for not found set b = 1;
 | ||
| set b = 0;
 | ||
| open c2;
 | ||
| c2_repeat: repeat
 | ||
| fetch c2 into c;
 | ||
| if (b = 1) then
 | ||
| leave c2_repeat;
 | ||
| end if;
 | ||
| insert into t4 values (c);
 | ||
| until b = 1
 | ||
| end repeat;
 | ||
| end;
 | ||
| end if;
 | ||
| end|
 | ||
| call bug12168('a')|
 | ||
| select * from t4|
 | ||
| a
 | ||
| 1
 | ||
| 3
 | ||
| truncate t4|
 | ||
| call bug12168('b')|
 | ||
| select * from t4|
 | ||
| a
 | ||
| 2
 | ||
| 4
 | ||
| truncate t4|
 | ||
| call bug12168('a')|
 | ||
| select * from t4|
 | ||
| a
 | ||
| 1
 | ||
| 3
 | ||
| truncate t4|
 | ||
| call bug12168('b')|
 | ||
| select * from t4|
 | ||
| a
 | ||
| 2
 | ||
| 4
 | ||
| truncate t4|
 | ||
| drop table t3, t4|
 | ||
| drop procedure bug12168|
 | ||
| create table t3 (c1 char(128))|
 | ||
| insert into t3 values 
 | ||
| ('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA')|
 | ||
| create procedure bug11333(i int)
 | ||
| begin
 | ||
| declare tmp varchar(128);
 | ||
| set @x = 0;
 | ||
| repeat
 | ||
| select c1 into tmp from t3
 | ||
| where c1 = 'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA';
 | ||
| set @x = @x + 1;
 | ||
| until @x >= i
 | ||
| end repeat;
 | ||
| end|
 | ||
| call bug11333(10)|
 | ||
| drop procedure bug11333|
 | ||
| drop table t3|
 | ||
| create function bug9048(f1 char binary) returns char
 | ||
| begin
 | ||
| set f1= concat( 'hello', f1 );
 | ||
| return f1;
 | ||
| end|
 | ||
| drop function bug9048|
 | ||
| create function bug9048(f1 char binary) returns char binary
 | ||
| begin
 | ||
| set f1= concat( 'hello', f1 );
 | ||
| return f1;
 | ||
| end|
 | ||
| select collation(bug9048("foo"))|
 | ||
| collation(bug9048("foo"))
 | ||
| utf8mb4_bin
 | ||
| drop function bug9048|
 | ||
| create procedure bug12849_1(inout x char) select x into x|
 | ||
| set @var='a'|
 | ||
| call bug12849_1(@var)|
 | ||
| select @var|
 | ||
| @var
 | ||
| a
 | ||
| drop procedure bug12849_1|
 | ||
| create procedure bug12849_2(inout foo varchar(15))
 | ||
| begin
 | ||
| select concat(foo, foo) INTO foo;
 | ||
| end|
 | ||
| set @var='abcd'|
 | ||
| call bug12849_2(@var)|
 | ||
| select @var|
 | ||
| @var
 | ||
| abcdabcd
 | ||
| drop procedure bug12849_2|
 | ||
| create procedure bug131333()
 | ||
| begin
 | ||
| begin
 | ||
| declare a int;
 | ||
| select a;
 | ||
| set a = 1;
 | ||
| select a;
 | ||
| end;
 | ||
| begin
 | ||
| declare b int;
 | ||
| select b;
 | ||
| end;
 | ||
| end|
 | ||
| create function bug131333()
 | ||
| returns int
 | ||
| begin
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = 1;
 | ||
| end;
 | ||
| begin
 | ||
| declare b int;
 | ||
| return b;
 | ||
| end;
 | ||
| end|
 | ||
| call bug131333()|
 | ||
| a
 | ||
| NULL
 | ||
| a
 | ||
| 1
 | ||
| b
 | ||
| NULL
 | ||
| select bug131333()|
 | ||
| bug131333()
 | ||
| NULL
 | ||
| drop procedure bug131333|
 | ||
| drop function bug131333|
 | ||
| create table t3 (c1 char(1) primary key not null)|
 | ||
| create function bug12379()
 | ||
| returns integer
 | ||
| begin
 | ||
| insert into t3 values('X');
 | ||
| insert into t3 values('X');
 | ||
| return 0;
 | ||
| end|
 | ||
| create procedure bug12379_1()
 | ||
| begin
 | ||
| declare exit handler for sqlexception select 42;
 | ||
| select bug12379();
 | ||
| END|
 | ||
| create procedure bug12379_2()
 | ||
| begin
 | ||
| declare exit handler for sqlexception begin end;
 | ||
| select bug12379();
 | ||
| end|
 | ||
| create procedure bug12379_3()
 | ||
| begin
 | ||
| select bug12379();
 | ||
| end|
 | ||
| select bug12379()|
 | ||
| ERROR 23000: Duplicate entry 'X' for key 'PRIMARY'
 | ||
| select 1|
 | ||
| 1
 | ||
| 1
 | ||
| call bug12379_1()|
 | ||
| bug12379()
 | ||
| 42
 | ||
| 42
 | ||
| select 2|
 | ||
| 2
 | ||
| 2
 | ||
| call bug12379_2()|
 | ||
| bug12379()
 | ||
| select 3|
 | ||
| 3
 | ||
| 3
 | ||
| call bug12379_3()|
 | ||
| ERROR 23000: Duplicate entry 'X' for key 'PRIMARY'
 | ||
| select 4|
 | ||
| 4
 | ||
| 4
 | ||
| drop function bug12379|
 | ||
| drop procedure bug12379_1|
 | ||
| drop procedure bug12379_2|
 | ||
| drop procedure bug12379_3|
 | ||
| drop table t3|
 | ||
| create procedure bug13124()
 | ||
| begin
 | ||
| declare y integer;
 | ||
| set @x=y;
 | ||
| end|
 | ||
| call bug13124()|
 | ||
| drop procedure  bug13124|
 | ||
| create procedure bug12979_1(inout d decimal(5)) set d = d / 2|
 | ||
| set @bug12979_user_var = NULL|
 | ||
| call bug12979_1(@bug12979_user_var)|
 | ||
| drop procedure bug12979_1|
 | ||
| create procedure bug12979_2()
 | ||
| begin
 | ||
| declare internal_var decimal(5);
 | ||
| set internal_var= internal_var / 2;
 | ||
| select internal_var;
 | ||
| end|
 | ||
| call bug12979_2()|
 | ||
| internal_var
 | ||
| NULL
 | ||
| drop procedure bug12979_2|
 | ||
| create table t3 (s1 int unique)|
 | ||
| set @sm=@@sql_mode|
 | ||
| set sql_mode='traditional'|
 | ||
| create procedure bug6127()
 | ||
| begin
 | ||
| declare continue handler for sqlstate '23000'
 | ||
|     begin
 | ||
| declare continue handler for sqlstate '22003'
 | ||
|         insert into t3 values (0);
 | ||
| insert into t3 values (1000000000000000);
 | ||
| end;
 | ||
| insert into t3 values (1);
 | ||
| insert into t3 values (1);
 | ||
| end|
 | ||
| call bug6127()|
 | ||
| select * from t3|
 | ||
| s1
 | ||
| 0
 | ||
| 1
 | ||
| call bug6127()|
 | ||
| ERROR 23000: Duplicate entry '0' for key 's1'
 | ||
| select * from t3|
 | ||
| s1
 | ||
| 0
 | ||
| 1
 | ||
| set sql_mode=@sm|
 | ||
| drop table t3|
 | ||
| drop procedure bug6127|
 | ||
| create procedure bug12589_1()
 | ||
| begin
 | ||
| declare spv1 decimal(3,3);
 | ||
| set spv1= 123.456;
 | ||
| set spv1 = 'test';
 | ||
| create temporary table tm1 as select spv1;
 | ||
| show create table tm1;
 | ||
| drop temporary table tm1;
 | ||
| end|
 | ||
| create procedure bug12589_2()
 | ||
| begin
 | ||
| declare spv1 decimal(6,3);
 | ||
| set spv1= 123.456;
 | ||
| create temporary table tm1 as select spv1;
 | ||
| show create table tm1;
 | ||
| drop temporary table tm1;
 | ||
| end|
 | ||
| create procedure bug12589_3()
 | ||
| begin
 | ||
| declare spv1 decimal(6,3);
 | ||
| set spv1= -123.456;
 | ||
| create temporary table tm1 as select spv1;
 | ||
| show create table tm1;
 | ||
| drop temporary table tm1;
 | ||
| end|
 | ||
| call bug12589_1()|
 | ||
| Table	Create Table
 | ||
| tm1	CREATE TEMPORARY TABLE `tm1` (
 | ||
|   `spv1` decimal(3,3) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| call bug12589_2()|
 | ||
| Table	Create Table
 | ||
| tm1	CREATE TEMPORARY TABLE `tm1` (
 | ||
|   `spv1` decimal(6,3) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| call bug12589_3()|
 | ||
| Table	Create Table
 | ||
| tm1	CREATE TEMPORARY TABLE `tm1` (
 | ||
|   `spv1` decimal(6,3) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| drop procedure bug12589_1|
 | ||
| drop procedure bug12589_2|
 | ||
| drop procedure bug12589_3|
 | ||
| create table t3 ( x int unique )|
 | ||
| create procedure bug7049_1()
 | ||
| begin
 | ||
| insert into t3 values (42);
 | ||
| insert into t3 values (42);
 | ||
| end|
 | ||
| create procedure bug7049_2()
 | ||
| begin
 | ||
| declare exit handler for sqlexception
 | ||
| select 'Caught it' as 'Result';
 | ||
| call bug7049_1();
 | ||
| select 'Missed it' as 'Result';
 | ||
| end|
 | ||
| create procedure bug7049_3()
 | ||
| call bug7049_1()|
 | ||
| create procedure bug7049_4()
 | ||
| begin
 | ||
| declare exit handler for sqlexception
 | ||
| select 'Caught it' as 'Result';
 | ||
| call bug7049_3();
 | ||
| select 'Missed it' as 'Result';
 | ||
| end|
 | ||
| create function bug7049_1()
 | ||
| returns int
 | ||
| begin
 | ||
| insert into t3 values (42);
 | ||
| insert into t3 values (42);
 | ||
| return 42;
 | ||
| end|
 | ||
| create function bug7049_2()
 | ||
| returns int
 | ||
| begin
 | ||
| declare x int default 0;
 | ||
| declare continue handler for sqlexception
 | ||
| set x = 1;
 | ||
| set x = bug7049_1();
 | ||
| return x;
 | ||
| end|
 | ||
| call bug7049_2()|
 | ||
| Result
 | ||
| Caught it
 | ||
| select * from t3|
 | ||
| x
 | ||
| 42
 | ||
| delete from t3|
 | ||
| call bug7049_4()|
 | ||
| Result
 | ||
| Caught it
 | ||
| select * from t3|
 | ||
| x
 | ||
| 42
 | ||
| select bug7049_2()|
 | ||
| bug7049_2()
 | ||
| 1
 | ||
| drop table t3|
 | ||
| drop procedure bug7049_1|
 | ||
| drop procedure bug7049_2|
 | ||
| drop procedure bug7049_3|
 | ||
| drop procedure bug7049_4|
 | ||
| drop function bug7049_1|
 | ||
| drop function bug7049_2|
 | ||
| create function bug13941(p_input_str text)
 | ||
| returns text
 | ||
| begin
 | ||
| declare p_output_str text;
 | ||
| set p_output_str = p_input_str;
 | ||
| set p_output_str = replace(p_output_str, 'xyzzy', 'plugh');
 | ||
| set p_output_str = replace(p_output_str, 'test', 'prova');
 | ||
| set p_output_str = replace(p_output_str, 'this', 'questo');
 | ||
| set p_output_str = replace(p_output_str, ' a ', 'una ');
 | ||
| set p_output_str = replace(p_output_str, 'is', '');
 | ||
| return p_output_str;
 | ||
| end|
 | ||
| create procedure bug13941(out sout varchar(128))
 | ||
| begin
 | ||
| set sout = 'Local';
 | ||
| set sout = ifnull(sout, 'DEF');
 | ||
| end|
 | ||
| select bug13941('this is a test')|
 | ||
| bug13941('this is a test')
 | ||
| questo una prova
 | ||
| call bug13941(@a)|
 | ||
| select @a|
 | ||
| @a
 | ||
| Local
 | ||
| drop function bug13941|
 | ||
| drop procedure bug13941|
 | ||
| CREATE PROCEDURE bug13095(tbl_name varchar(32))
 | ||
| BEGIN
 | ||
| SET @str =
 | ||
| CONCAT("CREATE TABLE ", tbl_name, "(stuff char(15))");
 | ||
| SELECT @str;
 | ||
| PREPARE stmt FROM @str;
 | ||
| EXECUTE stmt;
 | ||
| SET @str =
 | ||
| CONCAT("INSERT INTO ", tbl_name, " VALUES('row1'),('row2'),('row3')" );
 | ||
| SELECT @str;
 | ||
| PREPARE stmt FROM @str;
 | ||
| EXECUTE stmt;
 | ||
| SET @str =
 | ||
| CONCAT("CREATE VIEW bug13095_v1(c1) AS SELECT stuff FROM ", tbl_name);
 | ||
| SELECT @str;
 | ||
| PREPARE stmt FROM @str;
 | ||
| EXECUTE stmt;
 | ||
| SELECT * FROM bug13095_v1;
 | ||
| SET @str =
 | ||
| "DROP VIEW bug13095_v1";
 | ||
| SELECT @str;
 | ||
| PREPARE stmt FROM @str;
 | ||
| EXECUTE stmt;
 | ||
| END|
 | ||
| CALL bug13095('bug13095_t1');
 | ||
| @str
 | ||
| CREATE TABLE bug13095_t1(stuff char(15))
 | ||
| @str
 | ||
| INSERT INTO bug13095_t1 VALUES('row1'),('row2'),('row3')
 | ||
| @str
 | ||
| CREATE VIEW bug13095_v1(c1) AS SELECT stuff FROM bug13095_t1
 | ||
| c1
 | ||
| row1
 | ||
| row2
 | ||
| row3
 | ||
| @str
 | ||
| DROP VIEW bug13095_v1
 | ||
| DROP PROCEDURE bug13095;
 | ||
| DROP TABLE bug13095_t1;
 | ||
| /*!50003 create function bug14723()
 | ||
| returns bigint(20)
 | ||
| main_loop: begin
 | ||
| return 42;
 | ||
| end */;;
 | ||
| show create function bug14723;;
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug14723		CREATE DEFINER=`root`@`localhost` FUNCTION `bug14723`() RETURNS bigint(20)
 | ||
| main_loop: begin
 | ||
| return 42;
 | ||
| end	latin1	utf8mb4_uca1400_ai_ci	utf8mb4_uca1400_ai_ci
 | ||
| select bug14723();;
 | ||
| bug14723()
 | ||
| 42
 | ||
| /*!50003 create procedure bug14723()
 | ||
| main_loop: begin
 | ||
| select 42;
 | ||
| end */;;
 | ||
| show create procedure bug14723;;
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug14723		CREATE DEFINER=`root`@`localhost` PROCEDURE `bug14723`()
 | ||
| main_loop: begin
 | ||
| select 42;
 | ||
| end	latin1	utf8mb4_uca1400_ai_ci	utf8mb4_uca1400_ai_ci
 | ||
| call bug14723();;
 | ||
| 42
 | ||
| 42
 | ||
| drop function bug14723|
 | ||
| drop procedure bug14723|
 | ||
| create procedure bug14845()
 | ||
| begin
 | ||
| declare a char(255);
 | ||
| declare done int default 0;
 | ||
| declare c cursor for select count(*) from t1 where 1 = 0;
 | ||
| declare continue handler for sqlstate '02000' set done = 1;
 | ||
| open c;
 | ||
| repeat
 | ||
| fetch c into a;
 | ||
| if not done then
 | ||
| select a;
 | ||
| end if;
 | ||
| until done end repeat;
 | ||
| close c;
 | ||
| end|
 | ||
| call bug14845()|
 | ||
| a
 | ||
| 0
 | ||
| drop procedure bug14845|
 | ||
| CREATE PROCEDURE `bug13549_2`()
 | ||
| begin
 | ||
| call bug13549_1();
 | ||
| end|
 | ||
| CREATE PROCEDURE `bug13549_1`()
 | ||
| begin
 | ||
| declare done int default 0;
 | ||
| set done= not done;
 | ||
| end|
 | ||
| CALL bug13549_2()|
 | ||
| drop procedure bug13549_2|
 | ||
| drop procedure bug13549_1|
 | ||
| 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=4|
 | ||
| select @@max_sp_recursion_depth|
 | ||
| @@max_sp_recursion_depth
 | ||
| 4
 | ||
| select bug10100f(3)|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| select bug10100f(6)|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| call bug10100t(5)|
 | ||
| res
 | ||
| 120
 | ||
| call bug10100pt(1,5)|
 | ||
| a
 | ||
| 4
 | ||
| call bug10100pv(1,5)|
 | ||
| a
 | ||
| 4
 | ||
| update t3 set a=1|
 | ||
| call bug10100pd(1,5)|
 | ||
| level
 | ||
| 1
 | ||
| a
 | ||
| 7
 | ||
| a
 | ||
| 7
 | ||
| level
 | ||
| 2
 | ||
| a
 | ||
| 13
 | ||
| a
 | ||
| 13
 | ||
| level
 | ||
| 3
 | ||
| a
 | ||
| 19
 | ||
| a
 | ||
| 19
 | ||
| level
 | ||
| 4
 | ||
| a
 | ||
| 25
 | ||
| a
 | ||
| 25
 | ||
| a
 | ||
| 25
 | ||
| select * from t3|
 | ||
| a
 | ||
| 25
 | ||
| update t3 set a=1|
 | ||
| call bug10100pc(1,5)|
 | ||
| level
 | ||
| 1
 | ||
| lv
 | ||
| 1
 | ||
| level
 | ||
| 2
 | ||
| lv
 | ||
| 2
 | ||
| level
 | ||
| 3
 | ||
| lv
 | ||
| 4
 | ||
| level
 | ||
| 4
 | ||
| lv
 | ||
| 7
 | ||
| a
 | ||
| 11
 | ||
| select * from t3|
 | ||
| a
 | ||
| 11
 | ||
| set @@max_sp_recursion_depth=0|
 | ||
| select @@max_sp_recursion_depth|
 | ||
| @@max_sp_recursion_depth
 | ||
| 0
 | ||
| select bug10100f(5)|
 | ||
| ERROR HY000: Recursive stored functions and triggers are not allowed
 | ||
| call bug10100t(5)|
 | ||
| ERROR HY000: Recursive limit 0 (as set by the max_sp_recursion_depth variable) was exceeded for routine bug10100p
 | ||
| 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|
 | ||
| create table t3 (s1 int, primary key (s1))|
 | ||
| insert into t3 values (1),(2)|
 | ||
| create procedure bug13729()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 55;
 | ||
| update t3 set s1 = 1;
 | ||
| end|
 | ||
| call bug13729()|
 | ||
| 55
 | ||
| 55
 | ||
| select * from t3|
 | ||
| s1
 | ||
| 1
 | ||
| 2
 | ||
| drop procedure bug13729|
 | ||
| drop table t3|
 | ||
| create procedure bug14643_1()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 'boo' as 'Handler';
 | ||
| begin
 | ||
| declare v int default undefined_var;
 | ||
| if v = 1 then
 | ||
| select 1;
 | ||
| else
 | ||
| select v, isnull(v);
 | ||
| end if;
 | ||
| end;
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: undefined_var
 | ||
| create procedure bug14643_2()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 'boo' as 'Handler';
 | ||
| case undefined_var
 | ||
| when 1 then
 | ||
| select 1;
 | ||
| else
 | ||
| select 2;
 | ||
| end case;
 | ||
| select undefined_var;
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: undefined_var
 | ||
| create table t3(a int primary key auto_increment)|
 | ||
| create table t4(a int primary key auto_increment)|
 | ||
| create procedure bug14304()
 | ||
| begin
 | ||
| insert into t3 set a=null;
 | ||
| insert into t4 set a=null;
 | ||
| insert into t4 set a=null;
 | ||
| insert into t4 set a=null;
 | ||
| insert into t4 set a=null;
 | ||
| insert into t4 set a=null;
 | ||
| insert into t4 select null as a;
 | ||
| insert into t3 set a=null;
 | ||
| insert into t3 set a=null;
 | ||
| select * from t3;
 | ||
| end|
 | ||
| call bug14304()|
 | ||
| a
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| drop procedure bug14304|
 | ||
| drop table t3, t4|
 | ||
| create procedure bug14376()
 | ||
| begin
 | ||
| declare x int default x;
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: x
 | ||
| create procedure bug14376()
 | ||
| begin
 | ||
| declare x int default 42;
 | ||
| begin
 | ||
| declare x int default x;
 | ||
| select x;
 | ||
| end;
 | ||
| end|
 | ||
| call bug14376()|
 | ||
| x
 | ||
| 42
 | ||
| drop procedure bug14376|
 | ||
| create procedure bug14376(x int)
 | ||
| begin
 | ||
| declare x int default x;
 | ||
| select x;
 | ||
| end|
 | ||
| call bug14376(4711)|
 | ||
| x
 | ||
| 4711
 | ||
| drop procedure bug14376|
 | ||
| create table t3 (a varchar(255))|
 | ||
| insert into t3 (a) values ("a - table column")|
 | ||
| create procedure bug5967(a varchar(255))
 | ||
| begin
 | ||
| declare i varchar(255);
 | ||
| declare c cursor for select a from t3;
 | ||
| select a;
 | ||
| select a from t3 into i;
 | ||
| select i as 'Parameter takes precedence over table column';                     open c;
 | ||
| fetch c into i;
 | ||
| close c;
 | ||
| select i as 'Parameter takes precedence over table column in cursors';
 | ||
| begin
 | ||
| declare a varchar(255) default 'a - local variable';
 | ||
| declare c1 cursor for select a from t3;
 | ||
| select a as 'A local variable takes precedence over parameter';
 | ||
| open c1;
 | ||
| fetch c1 into i;
 | ||
| close c1;
 | ||
| select i as 'A local variable takes precedence over parameter in cursors';
 | ||
| begin
 | ||
| declare a varchar(255) default 'a - local variable in a nested compound statement';
 | ||
| declare c2 cursor for select a from t3;
 | ||
| select a as 'A local variable in a nested compound statement takes precedence over a local variable in the outer statement';
 | ||
| select a from t3 into i;
 | ||
| select i as  'A local variable in a nested compound statement takes precedence over table column';
 | ||
| open c2;
 | ||
| fetch c2 into i;
 | ||
| close c2;
 | ||
| select i as  'A local variable in a nested compound statement takes precedence over table column in cursors';
 | ||
| end;
 | ||
| end;
 | ||
| end|
 | ||
| call bug5967("a - stored procedure parameter")|
 | ||
| a
 | ||
| a - stored procedure parameter
 | ||
| Parameter takes precedence over table column
 | ||
| a - stored procedure parameter
 | ||
| Parameter takes precedence over table column in cursors
 | ||
| a - stored procedure parameter
 | ||
| A local variable takes precedence over parameter
 | ||
| a - local variable
 | ||
| A local variable takes precedence over parameter in cursors
 | ||
| a - local variable
 | ||
| A local variable in a nested compound statement takes precedence over a local variable in the outer statement
 | ||
| a - local variable in a nested compound statement
 | ||
| A local variable in a nested compound statement takes precedence over table column
 | ||
| a - local variable in a nested compound statement
 | ||
| A local variable in a nested compound statement takes precedence over table column in cursors
 | ||
| a - local variable in a nested compound statement
 | ||
| drop procedure bug5967|
 | ||
| create procedure bug13012()
 | ||
| BEGIN
 | ||
| REPAIR TABLE t1;
 | ||
| END|
 | ||
| call bug13012()|
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	repair	status	OK
 | ||
| drop procedure bug13012|
 | ||
| create view v1 as select * from t1|
 | ||
| create procedure bug13012()
 | ||
| BEGIN
 | ||
| REPAIR TABLE t1,t2,t3,v1;
 | ||
| OPTIMIZE TABLE t1,t2,t3,v1;
 | ||
| ANALYZE TABLE t1,t2,t3,v1;
 | ||
| END|
 | ||
| call bug13012()|
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	repair	status	OK
 | ||
| test.t2	repair	status	OK
 | ||
| test.t3	repair	status	OK
 | ||
| test.v1	repair	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	repair	status	Operation failed
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	optimize	status	OK
 | ||
| test.t2	optimize	status	OK
 | ||
| test.t3	optimize	status	OK
 | ||
| test.v1	optimize	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	optimize	status	Operation failed
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	analyze	status	Engine-independent statistics collected
 | ||
| test.t1	analyze	status	Table is already up to date
 | ||
| test.t2	analyze	status	Engine-independent statistics collected
 | ||
| test.t2	analyze	status	Table is already up to date
 | ||
| test.t3	analyze	status	Engine-independent statistics collected
 | ||
| test.t3	analyze	status	Table is already up to date
 | ||
| test.v1	analyze	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	analyze	status	Operation failed
 | ||
| call bug13012()|
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	repair	status	OK
 | ||
| test.t2	repair	status	OK
 | ||
| test.t3	repair	status	OK
 | ||
| test.v1	repair	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	repair	status	Operation failed
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	optimize	status	OK
 | ||
| test.t2	optimize	status	OK
 | ||
| test.t3	optimize	status	OK
 | ||
| test.v1	optimize	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	optimize	status	Operation failed
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	analyze	status	Engine-independent statistics collected
 | ||
| test.t1	analyze	status	Table is already up to date
 | ||
| test.t2	analyze	status	Engine-independent statistics collected
 | ||
| test.t2	analyze	status	Table is already up to date
 | ||
| test.t3	analyze	status	Engine-independent statistics collected
 | ||
| test.t3	analyze	status	Table is already up to date
 | ||
| test.v1	analyze	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	analyze	status	Operation failed
 | ||
| call bug13012()|
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	repair	status	OK
 | ||
| test.t2	repair	status	OK
 | ||
| test.t3	repair	status	OK
 | ||
| test.v1	repair	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	repair	status	Operation failed
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	optimize	status	OK
 | ||
| test.t2	optimize	status	OK
 | ||
| test.t3	optimize	status	OK
 | ||
| test.v1	optimize	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	optimize	status	Operation failed
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.t1	analyze	status	Engine-independent statistics collected
 | ||
| test.t1	analyze	status	Table is already up to date
 | ||
| test.t2	analyze	status	Engine-independent statistics collected
 | ||
| test.t2	analyze	status	Table is already up to date
 | ||
| test.t3	analyze	status	Engine-independent statistics collected
 | ||
| test.t3	analyze	status	Table is already up to date
 | ||
| test.v1	analyze	Error	'test.v1' is not of type 'BASE TABLE'
 | ||
| test.v1	analyze	status	Operation failed
 | ||
| drop procedure bug13012|
 | ||
| drop view v1|
 | ||
| drop table t3|
 | ||
| select * from t1 order by data|
 | ||
| id	data
 | ||
| aa	0
 | ||
| aa	1
 | ||
| aa	2
 | ||
| aa	3
 | ||
| aa	4
 | ||
| aa	5
 | ||
| aa	6
 | ||
| aa	7
 | ||
| aa	8
 | ||
| aa	9
 | ||
| create schema mysqltest1|
 | ||
| create schema mysqltest2|
 | ||
| create schema mysqltest3|
 | ||
| use mysqltest3|
 | ||
| create procedure mysqltest1.p1 (out prequestid varchar(100))
 | ||
| begin
 | ||
| call mysqltest2.p2('call mysqltest3.p3(1, 2)');
 | ||
| end|
 | ||
| create procedure mysqltest2.p2(in psql text)
 | ||
| begin
 | ||
| declare lsql text;
 | ||
| set @lsql= psql;
 | ||
| prepare lstatement from @lsql;
 | ||
| execute lstatement;
 | ||
| deallocate prepare lstatement;
 | ||
| end|
 | ||
| create procedure mysqltest3.p3(in p1 int)
 | ||
| begin
 | ||
| select p1;
 | ||
| end|
 | ||
| call mysqltest1.p1(@rs)|
 | ||
| ERROR 42000: Incorrect number of arguments for PROCEDURE mysqltest3.p3; expected 1, got 2
 | ||
| call mysqltest1.p1(@rs)|
 | ||
| ERROR 42000: Incorrect number of arguments for PROCEDURE mysqltest3.p3; expected 1, got 2
 | ||
| call mysqltest1.p1(@rs)|
 | ||
| ERROR 42000: Incorrect number of arguments for PROCEDURE mysqltest3.p3; expected 1, got 2
 | ||
| drop schema mysqltest1|
 | ||
| drop schema mysqltest2|
 | ||
| drop schema mysqltest3|
 | ||
| use test|
 | ||
| create table t3 (id int not null primary key, county varchar(25))|
 | ||
| insert into t3 (id, county) values (1, 'York')|
 | ||
| create procedure bug15441(c varchar(25))
 | ||
| begin
 | ||
| update t3 set id=2, county=value(c);
 | ||
| end|
 | ||
| call bug15441('county')|
 | ||
| ERROR 42S22: Unknown column 'c' in 'SELECT'
 | ||
| drop procedure bug15441|
 | ||
| create procedure bug15441(county varchar(25))
 | ||
| begin
 | ||
| declare c varchar(25) default "hello";
 | ||
| insert into t3 (id, county) values (1, county)
 | ||
| on duplicate key update county= values(county);
 | ||
| select * from t3;
 | ||
| update t3 set id=2, county=value(id);
 | ||
| select * from t3;
 | ||
| end|
 | ||
| call bug15441('Yale')|
 | ||
| id	county
 | ||
| 1	Yale
 | ||
| id	county
 | ||
| 2	NULL
 | ||
| drop table t3|
 | ||
| drop procedure bug15441|
 | ||
| create procedure bug14498_1()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 'error' as 'Handler';
 | ||
| if v then
 | ||
| select 'yes' as 'v';
 | ||
| else
 | ||
| select 'no' as 'v';
 | ||
| end if;
 | ||
| select 'done' as 'End';
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: v
 | ||
| create procedure bug14498_2()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 'error' as 'Handler';
 | ||
| while v do
 | ||
| select 'yes' as 'v';
 | ||
| end while;
 | ||
| select 'done' as 'End';
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: v
 | ||
| create procedure bug14498_3()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 'error' as 'Handler';
 | ||
| repeat
 | ||
| select 'maybe' as 'v';
 | ||
| until v end repeat;
 | ||
| select 'done' as 'End';
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: v
 | ||
| create procedure bug14498_4()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 'error' as 'Handler';
 | ||
| case v
 | ||
| when 1 then
 | ||
| select '1' as 'v';
 | ||
| when 2 then
 | ||
| select '2' as 'v';
 | ||
| else
 | ||
| select '?' as 'v';
 | ||
| end case;
 | ||
| select 'done' as 'End';
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: v
 | ||
| create procedure bug14498_5()
 | ||
| begin
 | ||
| declare continue handler for sqlexception select 'error' as 'Handler';
 | ||
| case
 | ||
| when v = 1 then
 | ||
| select '1' as 'v';
 | ||
| when v = 2 then
 | ||
| select '2' as 'v';
 | ||
| else
 | ||
| select '?' as 'v';
 | ||
| end case;
 | ||
| select 'done' as 'End';
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: v
 | ||
| create table t3 (id int not null)|
 | ||
| create procedure bug15231_1()
 | ||
| begin
 | ||
| declare xid integer;
 | ||
| declare xdone integer default 0;
 | ||
| declare continue handler for not found set xdone = 1;
 | ||
| set xid=null;
 | ||
| call bug15231_2(xid);
 | ||
| select xid, xdone;
 | ||
| end|
 | ||
| create procedure bug15231_2(inout ioid integer)
 | ||
| begin
 | ||
| select "Before NOT FOUND condition is triggered" as '1';
 | ||
| select id into ioid from t3 where id=ioid;
 | ||
| select "After NOT FOUND condtition is triggered" as '2';
 | ||
| if ioid is null then
 | ||
| set ioid=1;
 | ||
| end if;
 | ||
| end|
 | ||
| create procedure bug15231_3()
 | ||
| begin
 | ||
| declare exit handler for sqlwarning
 | ||
| select 'Caught it (correct)' as 'Result';
 | ||
| call bug15231_4();
 | ||
| end|
 | ||
| create procedure bug15231_4()
 | ||
| begin
 | ||
| declare x decimal(2,1);
 | ||
| set x = 'zap';
 | ||
| select 'Missed it (correct)' as 'Result';
 | ||
| show warnings;
 | ||
| end|
 | ||
| create procedure bug15231_5()
 | ||
| begin
 | ||
| declare exit handler for sqlwarning
 | ||
| select 'Caught it (wrong)' as 'Result';
 | ||
| call bug15231_6();
 | ||
| end|
 | ||
| create procedure bug15231_6()
 | ||
| begin
 | ||
| declare x decimal(2,1);
 | ||
| set x = 'zap';
 | ||
| select 'Missed it (correct)' as 'Result';
 | ||
| select id from t3;
 | ||
| end|
 | ||
| call bug15231_1()|
 | ||
| 1
 | ||
| Before NOT FOUND condition is triggered
 | ||
| 2
 | ||
| After NOT FOUND condtition is triggered
 | ||
| xid	xdone
 | ||
| 1	1
 | ||
| call bug15231_3()|
 | ||
| Result
 | ||
| Missed it (correct)
 | ||
| Level	Code	Message
 | ||
| Warning	1366	Incorrect decimal value: 'zap' for column ``.``.`x` at row 0
 | ||
| Result
 | ||
| Caught it (correct)
 | ||
| call bug15231_5()|
 | ||
| Result
 | ||
| Missed it (correct)
 | ||
| id
 | ||
| drop table t3|
 | ||
| drop procedure bug15231_1|
 | ||
| drop procedure bug15231_2|
 | ||
| drop procedure bug15231_3|
 | ||
| drop procedure bug15231_4|
 | ||
| drop procedure bug15231_5|
 | ||
| drop procedure bug15231_6|
 | ||
| create table t3 (c1 int primary key)|
 | ||
| insert into t3 values (1)|
 | ||
| create procedure bug15011()
 | ||
| deterministic
 | ||
| begin
 | ||
| declare continue handler for 1062
 | ||
| select 'Outer' as 'Handler';
 | ||
| begin
 | ||
| declare continue handler for 1062
 | ||
| select 'Inner' as 'Handler';
 | ||
| insert into t3 values (1);
 | ||
| end;
 | ||
| end|
 | ||
| call bug15011()|
 | ||
| Handler
 | ||
| Inner
 | ||
| drop procedure bug15011|
 | ||
| drop table t3|
 | ||
| create table t3 ( d date )|
 | ||
| insert into t3 values
 | ||
| ( '2005-01-01' ), ( '2005-01-02' ), ( '2005-01-03' ),
 | ||
| ( '2005-01-04' ), ( '2005-02-01' ), ( '2005-02-02' )|
 | ||
| create procedure bug17476(pDateFormat varchar(10))
 | ||
| select date_format(t3.d, pDateFormat), count(*)
 | ||
| from t3 
 | ||
| group by date_format(t3.d, pDateFormat)|
 | ||
| call bug17476('%Y-%m')|
 | ||
| date_format(t3.d, pDateFormat)	count(*)
 | ||
| 2005-01	4
 | ||
| 2005-02	2
 | ||
| call bug17476('%Y-%m')|
 | ||
| date_format(t3.d, pDateFormat)	count(*)
 | ||
| 2005-01	4
 | ||
| 2005-02	2
 | ||
| drop table t3|
 | ||
| drop procedure bug17476|
 | ||
| create table t3 ( c varchar(1) )|
 | ||
| insert into t3 values
 | ||
| (' '),('.'),(';'),(','),('-'),('_'),('('),(')'),('/'),('\\')|
 | ||
| create procedure bug16887()
 | ||
| begin
 | ||
| declare i int default 10;
 | ||
| again:
 | ||
| while i > 0 do
 | ||
| begin
 | ||
| declare breakchar varchar(1);
 | ||
| declare done int default 0;
 | ||
| declare t3_cursor cursor for select c from t3;
 | ||
| declare continue handler for not found set done = 1;
 | ||
| set i = i - 1;
 | ||
| select i;
 | ||
| if i = 3 then
 | ||
| iterate again;
 | ||
| end if;
 | ||
| open t3_cursor;
 | ||
| loop
 | ||
| fetch t3_cursor into breakchar;
 | ||
| if done = 1 then
 | ||
| begin
 | ||
| close t3_cursor;
 | ||
| iterate again;
 | ||
| end;
 | ||
| end if;
 | ||
| end loop;
 | ||
| end;
 | ||
| end while;
 | ||
| end|
 | ||
| call bug16887()|
 | ||
| i
 | ||
| 9
 | ||
| i
 | ||
| 8
 | ||
| i
 | ||
| 7
 | ||
| i
 | ||
| 6
 | ||
| i
 | ||
| 5
 | ||
| i
 | ||
| 4
 | ||
| i
 | ||
| 3
 | ||
| i
 | ||
| 2
 | ||
| i
 | ||
| 1
 | ||
| i
 | ||
| 0
 | ||
| drop table t3|
 | ||
| drop procedure bug16887|
 | ||
| delete from t1|
 | ||
| insert into t1 values ('c', 2), ('b', 3), ('a', 1)|
 | ||
| create procedure bug16474_1()
 | ||
| begin
 | ||
| declare x int;
 | ||
| select id from t1 order by x, id;
 | ||
| end|
 | ||
| create table t3 (id int not null auto_increment primary key)|
 | ||
| create procedure bug14945() deterministic truncate t3|
 | ||
| insert into t3 values (null)|
 | ||
| call bug14945()|
 | ||
| insert into t3 values (null)|
 | ||
| select * from t3|
 | ||
| id
 | ||
| 1
 | ||
| drop table t3|
 | ||
| drop procedure bug14945|
 | ||
| create procedure bug16474_2(x int)
 | ||
| select id from t1 order by x, id|
 | ||
| call bug16474_1()|
 | ||
| id
 | ||
| a
 | ||
| b
 | ||
| c
 | ||
| call bug16474_2(1)|
 | ||
| id
 | ||
| a
 | ||
| b
 | ||
| c
 | ||
| call bug16474_2(2)|
 | ||
| id
 | ||
| a
 | ||
| b
 | ||
| c
 | ||
| drop procedure bug16474_1|
 | ||
| drop procedure bug16474_2|
 | ||
| set @x = 2|
 | ||
| select * from t1 order by @x, data|
 | ||
| id	data
 | ||
| a	1
 | ||
| c	2
 | ||
| b	3
 | ||
| delete from t1|
 | ||
| create table t3 (
 | ||
| id int not null auto_increment,
 | ||
| primary key (id)
 | ||
| )|
 | ||
| create function bug15728() returns int(11)
 | ||
| return last_insert_id()|
 | ||
| insert into t3 values (0)|
 | ||
| select last_insert_id()|
 | ||
| last_insert_id()
 | ||
| 1
 | ||
| select bug15728()|
 | ||
| bug15728()
 | ||
| 1
 | ||
| drop function bug15728|
 | ||
| drop table t3|
 | ||
| create procedure bug18787()
 | ||
| begin
 | ||
| declare continue handler for sqlexception begin end;
 | ||
| select no_such_function();
 | ||
| end|
 | ||
| call bug18787()|
 | ||
| drop procedure bug18787|
 | ||
| create database bug18344_012345678901|
 | ||
| use bug18344_012345678901|
 | ||
| create procedure bug18344() begin end|
 | ||
| create procedure bug18344_2() begin end|
 | ||
| create database bug18344_0123456789012|
 | ||
| use bug18344_0123456789012|
 | ||
| create procedure bug18344() begin end|
 | ||
| create procedure bug18344_2() begin end|
 | ||
| use test|
 | ||
| select schema_name from information_schema.schemata where 
 | ||
| schema_name like 'bug18344%'|
 | ||
| schema_name
 | ||
| bug18344_012345678901
 | ||
| bug18344_0123456789012
 | ||
| select routine_name,routine_schema from information_schema.routines where
 | ||
| routine_schema like 'bug18344%'|
 | ||
| routine_name	routine_schema
 | ||
| bug18344	bug18344_012345678901
 | ||
| bug18344	bug18344_0123456789012
 | ||
| bug18344_2	bug18344_012345678901
 | ||
| bug18344_2	bug18344_0123456789012
 | ||
| drop database bug18344_012345678901|
 | ||
| drop database bug18344_0123456789012|
 | ||
| select schema_name from information_schema.schemata where 
 | ||
| schema_name like 'bug18344%'|
 | ||
| schema_name
 | ||
| select routine_name,routine_schema from information_schema.routines where
 | ||
| routine_schema like 'bug18344%'|
 | ||
| routine_name	routine_schema
 | ||
| create function bug12472() returns int return (select count(*) from t1)|
 | ||
| create table t3 as select bug12472() as i|
 | ||
| show create table t3|
 | ||
| Table	Create Table
 | ||
| t3	CREATE TABLE `t3` (
 | ||
|   `i` int(11) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| select * from t3|
 | ||
| i
 | ||
| 0
 | ||
| drop table t3|
 | ||
| create view v1 as select bug12472() as j|
 | ||
| create table t3 as select * from v1|
 | ||
| show create table t3|
 | ||
| Table	Create Table
 | ||
| t3	CREATE TABLE `t3` (
 | ||
|   `j` int(11) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| select * from t3|
 | ||
| j
 | ||
| 0
 | ||
| drop table t3|
 | ||
| drop view v1|
 | ||
| drop function bug12472|
 | ||
| CREATE FUNCTION bug18589_f1(arg TEXT) RETURNS TEXT
 | ||
| BEGIN
 | ||
| RETURN CONCAT(arg, "");
 | ||
| END|
 | ||
| CREATE PROCEDURE bug18589_p1(arg TEXT, OUT ret TEXT)
 | ||
| BEGIN
 | ||
| SET ret = CONCAT(arg, "");
 | ||
| END|
 | ||
| CREATE PROCEDURE bug18589_p2(arg TEXT)
 | ||
| BEGIN
 | ||
| DECLARE v TEXT;
 | ||
| CALL bug18589_p1(arg, v);
 | ||
| SELECT v;
 | ||
| END|
 | ||
| SELECT bug18589_f1(REPEAT("a", 767))|
 | ||
| bug18589_f1(REPEAT("a", 767))
 | ||
| aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
 | ||
| SET @bug18589_v1 = ""|
 | ||
| CALL bug18589_p1(REPEAT("a", 767), @bug18589_v1)|
 | ||
| SELECT @bug18589_v1|
 | ||
| @bug18589_v1
 | ||
| aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
 | ||
| CALL bug18589_p2(REPEAT("a", 767))|
 | ||
| v
 | ||
| aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
 | ||
| DROP FUNCTION bug18589_f1|
 | ||
| DROP PROCEDURE bug18589_p1|
 | ||
| DROP PROCEDURE bug18589_p2|
 | ||
| CREATE FUNCTION bug18037_f1() RETURNS INT
 | ||
| BEGIN
 | ||
| RETURN @@server_id;
 | ||
| END|
 | ||
| CREATE PROCEDURE bug18037_p1()
 | ||
| BEGIN
 | ||
| DECLARE v INT DEFAULT @@server_id;
 | ||
| END|
 | ||
| CREATE PROCEDURE bug18037_p2()
 | ||
| BEGIN
 | ||
| CASE @@server_id
 | ||
| WHEN -1 THEN
 | ||
| SELECT 0;
 | ||
| ELSE
 | ||
| SELECT 1;
 | ||
| END CASE;
 | ||
| END|
 | ||
| SELECT bug18037_f1()|
 | ||
| bug18037_f1()
 | ||
| 1
 | ||
| CALL bug18037_p1()|
 | ||
| CALL bug18037_p2()|
 | ||
| 1
 | ||
| 1
 | ||
| DROP FUNCTION bug18037_f1|
 | ||
| DROP PROCEDURE bug18037_p1|
 | ||
| DROP PROCEDURE bug18037_p2|
 | ||
| use test|
 | ||
| create table t3 (i int)|
 | ||
| insert into t3 values (1), (2)|
 | ||
| create database mysqltest1|
 | ||
| use mysqltest1|
 | ||
| create function bug17199() returns varchar(2) deterministic return 'ok'|
 | ||
| use test|
 | ||
| select *, mysqltest1.bug17199() from t3|
 | ||
| i	mysqltest1.bug17199()
 | ||
| 1	ok
 | ||
| 2	ok
 | ||
| use mysqltest1|
 | ||
| create function bug18444(i int) returns int no sql deterministic return i + 1|
 | ||
| use test|
 | ||
| select mysqltest1.bug18444(i) from t3|
 | ||
| mysqltest1.bug18444(i)
 | ||
| 2
 | ||
| 3
 | ||
| drop table t3|
 | ||
| drop database mysqltest1|
 | ||
| create database mysqltest1 charset=utf8|
 | ||
| create database mysqltest2 charset=utf8|
 | ||
| create procedure mysqltest1.p1()
 | ||
| begin
 | ||
| -- alters the default collation of database test 
 | ||
| alter database character set koi8r;
 | ||
| end|
 | ||
| use mysqltest1|
 | ||
| call p1()|
 | ||
| show create database mysqltest1|
 | ||
| Database	Create Database
 | ||
| mysqltest1	CREATE DATABASE `mysqltest1` /*!40100 DEFAULT CHARACTER SET koi8r COLLATE koi8r_general_ci */
 | ||
| show create database mysqltest2|
 | ||
| Database	Create Database
 | ||
| mysqltest2	CREATE DATABASE `mysqltest2` /*!40100 DEFAULT CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci */
 | ||
| alter database mysqltest1 character set utf8|
 | ||
| use mysqltest2|
 | ||
| call mysqltest1.p1()|
 | ||
| show create database mysqltest1|
 | ||
| Database	Create Database
 | ||
| mysqltest1	CREATE DATABASE `mysqltest1` /*!40100 DEFAULT CHARACTER SET koi8r COLLATE koi8r_general_ci */
 | ||
| show create database mysqltest2|
 | ||
| Database	Create Database
 | ||
| mysqltest2	CREATE DATABASE `mysqltest2` /*!40100 DEFAULT CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci */
 | ||
| drop database mysqltest1|
 | ||
| drop database mysqltest2|
 | ||
| use test|
 | ||
| create table t3 as select 1|
 | ||
| create procedure bug15217()
 | ||
| begin
 | ||
| declare var1 char(255);
 | ||
| declare cur1 cursor for select * from t3;
 | ||
| open cur1;
 | ||
| fetch cur1 into var1;
 | ||
| select concat('data was: /', var1, '/');
 | ||
| close cur1;
 | ||
| end |
 | ||
| call bug15217()|
 | ||
| concat('data was: /', var1, '/')
 | ||
| data was: /1/
 | ||
| flush tables |
 | ||
| call bug15217()|
 | ||
| concat('data was: /', var1, '/')
 | ||
| data was: /1/
 | ||
| drop table t3|
 | ||
| drop procedure bug15217|
 | ||
| CREATE PROCEDURE bug21013(IN lim INT)
 | ||
| BEGIN
 | ||
| DECLARE i INT DEFAULT 0;
 | ||
| WHILE (i < lim) DO
 | ||
| SET @b = LOCATE(_latin1'b', @a, 1);
 | ||
| SET i = i + 1;
 | ||
| END WHILE;
 | ||
| END |
 | ||
| SET @a = _latin2"aaaaaaaaaa" |
 | ||
| CALL bug21013(10) |
 | ||
| DROP PROCEDURE bug21013 |
 | ||
| CREATE DATABASE mysqltest1 DEFAULT CHARACTER SET utf8|
 | ||
| CREATE DATABASE mysqltest2 DEFAULT CHARACTER SET utf8|
 | ||
| use mysqltest1|
 | ||
| CREATE FUNCTION bug16211_f1() RETURNS CHAR(10)
 | ||
| RETURN ""|
 | ||
| CREATE FUNCTION bug16211_f2() RETURNS CHAR(10) CHARSET koi8r
 | ||
| RETURN ""|
 | ||
| CREATE FUNCTION mysqltest2.bug16211_f3() RETURNS CHAR(10)
 | ||
| RETURN ""|
 | ||
| CREATE FUNCTION mysqltest2.bug16211_f4() RETURNS CHAR(10) CHARSET koi8r
 | ||
| RETURN ""|
 | ||
| SHOW CREATE FUNCTION bug16211_f1|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f1		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f1`() RETURNS char(10) CHARSET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SHOW CREATE FUNCTION bug16211_f2|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f2		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f2`() RETURNS char(10) CHARSET koi8r COLLATE koi8r_general_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SHOW CREATE FUNCTION mysqltest2.bug16211_f3|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f3		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f3`() RETURNS char(10) CHARSET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SHOW CREATE FUNCTION mysqltest2.bug16211_f4|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f4		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f4`() RETURNS char(10) CHARSET koi8r COLLATE koi8r_general_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest1" AND ROUTINE_NAME = "bug16211_f1"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest1" AND ROUTINE_NAME = "bug16211_f2"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest2" AND ROUTINE_NAME = "bug16211_f3"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest2" AND ROUTINE_NAME = "bug16211_f4"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT CHARSET(bug16211_f1())|
 | ||
| CHARSET(bug16211_f1())
 | ||
| utf8mb3
 | ||
| SELECT CHARSET(bug16211_f2())|
 | ||
| CHARSET(bug16211_f2())
 | ||
| koi8r
 | ||
| SELECT CHARSET(mysqltest2.bug16211_f3())|
 | ||
| CHARSET(mysqltest2.bug16211_f3())
 | ||
| utf8mb3
 | ||
| SELECT CHARSET(mysqltest2.bug16211_f4())|
 | ||
| CHARSET(mysqltest2.bug16211_f4())
 | ||
| koi8r
 | ||
| ALTER DATABASE mysqltest1 CHARACTER SET cp1251|
 | ||
| ALTER DATABASE mysqltest2 CHARACTER SET cp1251|
 | ||
| SHOW CREATE FUNCTION bug16211_f1|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f1		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f1`() RETURNS char(10) CHARSET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SHOW CREATE FUNCTION bug16211_f2|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f2		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f2`() RETURNS char(10) CHARSET koi8r COLLATE koi8r_general_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SHOW CREATE FUNCTION mysqltest2.bug16211_f3|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f3		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f3`() RETURNS char(10) CHARSET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SHOW CREATE FUNCTION mysqltest2.bug16211_f4|
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| bug16211_f4		CREATE DEFINER=`root`@`localhost` FUNCTION `bug16211_f4`() RETURNS char(10) CHARSET koi8r COLLATE koi8r_general_ci
 | ||
| RETURN ""	latin1	utf8mb4_uca1400_ai_ci	utf8mb3_uca1400_ai_ci
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest1" AND ROUTINE_NAME = "bug16211_f1"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest1" AND ROUTINE_NAME = "bug16211_f2"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest2" AND ROUTINE_NAME = "bug16211_f3"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT dtd_identifier
 | ||
| FROM INFORMATION_SCHEMA.ROUTINES
 | ||
| WHERE ROUTINE_SCHEMA = "mysqltest2" AND ROUTINE_NAME = "bug16211_f4"|
 | ||
| dtd_identifier
 | ||
| char(10)
 | ||
| SELECT CHARSET(bug16211_f1())|
 | ||
| CHARSET(bug16211_f1())
 | ||
| utf8mb3
 | ||
| SELECT CHARSET(bug16211_f2())|
 | ||
| CHARSET(bug16211_f2())
 | ||
| koi8r
 | ||
| SELECT CHARSET(mysqltest2.bug16211_f3())|
 | ||
| CHARSET(mysqltest2.bug16211_f3())
 | ||
| utf8mb3
 | ||
| SELECT CHARSET(mysqltest2.bug16211_f4())|
 | ||
| CHARSET(mysqltest2.bug16211_f4())
 | ||
| koi8r
 | ||
| use test|
 | ||
| DROP DATABASE mysqltest1|
 | ||
| DROP DATABASE mysqltest2|
 | ||
| CREATE DATABASE mysqltest1 DEFAULT CHARACTER SET utf8|
 | ||
| use mysqltest1|
 | ||
| CREATE PROCEDURE bug16676_p1(
 | ||
| IN p1 CHAR(10),
 | ||
| INOUT p2 CHAR(10),
 | ||
| OUT p3 CHAR(10))
 | ||
| BEGIN
 | ||
| SELECT CHARSET(p1), COLLATION(p1);
 | ||
| SELECT CHARSET(p2), COLLATION(p2);
 | ||
| SELECT CHARSET(p3), COLLATION(p3);
 | ||
| END|
 | ||
| CREATE PROCEDURE bug16676_p2(
 | ||
| IN p1 CHAR(10) CHARSET koi8r,
 | ||
| INOUT p2 CHAR(10) CHARSET cp1251,
 | ||
| OUT p3 CHAR(10) CHARSET greek)
 | ||
| BEGIN
 | ||
| SELECT CHARSET(p1), COLLATION(p1);
 | ||
| SELECT CHARSET(p2), COLLATION(p2);
 | ||
| SELECT CHARSET(p3), COLLATION(p3);
 | ||
| END|
 | ||
| SET @v2 = 'b'|
 | ||
| SET @v3 = 'c'|
 | ||
| CALL bug16676_p1('a', @v2, @v3)|
 | ||
| CHARSET(p1)	COLLATION(p1)
 | ||
| utf8mb3	utf8mb3_uca1400_ai_ci
 | ||
| CHARSET(p2)	COLLATION(p2)
 | ||
| utf8mb3	utf8mb3_uca1400_ai_ci
 | ||
| CHARSET(p3)	COLLATION(p3)
 | ||
| utf8mb3	utf8mb3_uca1400_ai_ci
 | ||
| CALL bug16676_p2('a', @v2, @v3)|
 | ||
| CHARSET(p1)	COLLATION(p1)
 | ||
| koi8r	koi8r_general_ci
 | ||
| CHARSET(p2)	COLLATION(p2)
 | ||
| cp1251	cp1251_general_ci
 | ||
| CHARSET(p3)	COLLATION(p3)
 | ||
| greek	greek_general_ci
 | ||
| use test|
 | ||
| DROP DATABASE mysqltest1|
 | ||
| create table t3 (a int)|
 | ||
| create table t4 (a int)|
 | ||
| insert into t3 values (1), (1), (2), (3)|
 | ||
| insert into t4 values (1), (1)|
 | ||
| create procedure bug8153_subselect()
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| select 'statement failed';
 | ||
| end;
 | ||
| update t3 set a=a+1 where (select a from t4 where a=1) is null;
 | ||
| select 'statement after update';
 | ||
| end|
 | ||
| call bug8153_subselect()|
 | ||
| statement failed
 | ||
| statement failed
 | ||
| statement after update
 | ||
| statement after update
 | ||
| select * from t3|
 | ||
| a
 | ||
| 1
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| call bug8153_subselect()|
 | ||
| statement failed
 | ||
| statement failed
 | ||
| statement after update
 | ||
| statement after update
 | ||
| select * from t3|
 | ||
| a
 | ||
| 1
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| drop procedure bug8153_subselect|
 | ||
| create procedure bug8153_subselect_a()
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| select 'in continue handler';
 | ||
| end;
 | ||
| select 'reachable code a1';
 | ||
| call bug8153_subselect_b();
 | ||
| select 'reachable code a2';
 | ||
| end|
 | ||
| create procedure bug8153_subselect_b()
 | ||
| begin
 | ||
| select 'reachable code b1';
 | ||
| update t3 set a=a+1 where (select a from t4 where a=1) is null;
 | ||
| select 'unreachable code b2';
 | ||
| end|
 | ||
| call bug8153_subselect_a()|
 | ||
| reachable code a1
 | ||
| reachable code a1
 | ||
| reachable code b1
 | ||
| reachable code b1
 | ||
| in continue handler
 | ||
| in continue handler
 | ||
| reachable code a2
 | ||
| reachable code a2
 | ||
| select * from t3|
 | ||
| a
 | ||
| 1
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| call bug8153_subselect_a()|
 | ||
| reachable code a1
 | ||
| reachable code a1
 | ||
| reachable code b1
 | ||
| reachable code b1
 | ||
| in continue handler
 | ||
| in continue handler
 | ||
| reachable code a2
 | ||
| reachable code a2
 | ||
| select * from t3|
 | ||
| a
 | ||
| 1
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| drop procedure bug8153_subselect_a|
 | ||
| drop procedure bug8153_subselect_b|
 | ||
| create procedure bug8153_proc_a()
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| select 'in continue handler';
 | ||
| end;
 | ||
| select 'reachable code a1';
 | ||
| call bug8153_proc_b();
 | ||
| select 'reachable code a2';
 | ||
| end|
 | ||
| create procedure bug8153_proc_b()
 | ||
| begin
 | ||
| select 'reachable code b1';
 | ||
| select no_such_function();
 | ||
| select 'unreachable code b2';
 | ||
| end|
 | ||
| call bug8153_proc_a()|
 | ||
| reachable code a1
 | ||
| reachable code a1
 | ||
| reachable code b1
 | ||
| reachable code b1
 | ||
| in continue handler
 | ||
| in continue handler
 | ||
| reachable code a2
 | ||
| reachable code a2
 | ||
| drop procedure bug8153_proc_a|
 | ||
| drop procedure bug8153_proc_b|
 | ||
| drop table t3|
 | ||
| drop table t4|
 | ||
| CREATE TABLE t11 (a INT)|
 | ||
| CREATE TABLE t12 (a INT)|
 | ||
| CREATE FUNCTION bug19862(x INT) RETURNS INT
 | ||
| BEGIN
 | ||
| INSERT INTO t11 VALUES (x);
 | ||
| RETURN x+1;
 | ||
| END|
 | ||
| INSERT INTO t12 VALUES (1), (2)|
 | ||
| SELECT bug19862(a) FROM t12 ORDER BY 1|
 | ||
| bug19862(a)
 | ||
| 2
 | ||
| 3
 | ||
| SELECT * FROM t11|
 | ||
| a
 | ||
| 1
 | ||
| 2
 | ||
| DROP TABLE t11, t12|
 | ||
| DROP FUNCTION bug19862|
 | ||
| create table t3 (a int)|
 | ||
| insert into t3 (a) values (1), (2)|
 | ||
| create database mysqltest1|
 | ||
| use mysqltest1|
 | ||
| drop database mysqltest1|
 | ||
| select database()|
 | ||
| database()
 | ||
| NULL
 | ||
| select * from (select 1 as a) as t1 natural join (select * from test.t3) as t2|
 | ||
| a
 | ||
| 1
 | ||
| use test|
 | ||
| drop table t3|
 | ||
| CREATE DEFINER=longer_than_80_456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789@localhost PROCEDURE bug16899_p1()
 | ||
| BEGIN
 | ||
| SET @a = 1;
 | ||
| END|
 | ||
| ERROR HY000: String 'longer_than_80_4567890123456789012345678901234567890123456789012345...' is too long for user name (should be no longer than 128)
 | ||
| CREATE DEFINER=some_user_name@1234567890abcdefghij1234567890abcdefghij1234567890abcdefghijQWERTY1234567890abcdefghij1234567890abcdefghij1234567890abcdefghijQWERTY1234567890abcdefghij1234567890abcdefghij1234567890abcdefghijQWERTY1234567890abcdefghij1234567890abcdefghij1234567890abcdefghijQWERTY1234567890abcdefghij1234567890abcdefghij1234567890abcdefghijQWERTY
 | ||
| FUNCTION bug16899_f1() RETURNS INT
 | ||
| BEGIN
 | ||
| RETURN 1;
 | ||
| END|
 | ||
| ERROR HY000: String '1234567890abcdefghij1234567890abcdefghij1234567890abcdefghijQWERTY1...' is too long for host name (should be no longer than 255)
 | ||
| create procedure bug21416() show create procedure bug21416|
 | ||
| call bug21416()|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| bug21416		CREATE DEFINER=`root`@`localhost` PROCEDURE `bug21416`()
 | ||
| show create procedure bug21416	latin1	utf8mb4_uca1400_ai_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure bug21416|
 | ||
| CREATE PROCEDURE bug21414() SELECT 1|
 | ||
| FLUSH TABLES WITH READ LOCK|
 | ||
| DROP PROCEDURE bug21414|
 | ||
| ERROR HY000: Can't execute the query because you have a conflicting read lock
 | ||
| UNLOCK TABLES|
 | ||
| The following should succeed.
 | ||
| DROP PROCEDURE bug21414|
 | ||
| set names utf8|
 | ||
| create database това_е_дълго_име_за_база_данни_нали|
 | ||
| INSERT INTO mysql.proc VALUES ('това_е_дълго_име_за_база_данни_нали','това_е_процедура_с_доста_дълго_име_нали_и_още_по_дълго','PROCEDURE','това_е_процедура_с_доста_дълго_име_нали_и_още_по_дълго','SQL','CONTAINS_SQL','NO','DEFINER','','','bad_body','root@localhost',now(), now(),'','', 'utf8', 'utf8_general_ci', 'utf8_general_ci', 'n/a', 'NONE')|
 | ||
| call това_е_дълго_име_за_база_данни_нали.това_е_процедура_с_доста_дълго_име_нали_и_още_по_дълго()|
 | ||
| ERROR HY000: Failed to load routine това_е_дълго_име_за_база_данни_нали.това_е_процедура_с_доста_дълго_име_нали_и_още_по_дълго (internal code -6). For more details, run SHOW WARNINGS
 | ||
| drop database това_е_дълго_име_за_база_данни_нали|
 | ||
| show warnings|
 | ||
| Level	Code	Message
 | ||
| Error	1064	You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '' at line 2
 | ||
| Error	1457	Failed to load routine това_е_дълго_име_за_база_данни_нали.това_е_процедура_с_доста_дълго_име_нали_и_още_по_дълго (internal code -6). For more details, run SHOW WARNINGS
 | ||
| CREATE TABLE t3 (
 | ||
| Member_ID varchar(15) NOT NULL,
 | ||
| PRIMARY KEY (Member_ID)
 | ||
| )|
 | ||
| CREATE TABLE t4 (
 | ||
| ID int(10) unsigned NOT NULL auto_increment,
 | ||
| Member_ID varchar(15) NOT NULL default '',
 | ||
| Action varchar(12) NOT NULL,
 | ||
| Action_Date datetime NOT NULL,
 | ||
| Track varchar(15) default NULL,
 | ||
| User varchar(12) default NULL,
 | ||
| Date_Updated timestamp NOT NULL default CURRENT_TIMESTAMP on update
 | ||
| CURRENT_TIMESTAMP,
 | ||
| PRIMARY KEY (ID),
 | ||
| KEY Action (Action),
 | ||
| KEY Action_Date (Action_Date)
 | ||
| )|
 | ||
| INSERT INTO t3(Member_ID) VALUES
 | ||
| ('111111'), ('222222'), ('333333'), ('444444'), ('555555'), ('666666')|
 | ||
| INSERT INTO t4(Member_ID, Action, Action_Date, Track) VALUES
 | ||
| ('111111', 'Disenrolled', '2006-03-01', 'CAD' ),
 | ||
| ('111111', 'Enrolled', '2006-03-01', 'CAD' ),
 | ||
| ('111111', 'Disenrolled', '2006-07-03', 'CAD' ),
 | ||
| ('222222', 'Enrolled', '2006-03-07', 'CAD' ),
 | ||
| ('222222', 'Enrolled', '2006-03-07', 'CHF' ),
 | ||
| ('222222', 'Disenrolled', '2006-08-02', 'CHF' ),
 | ||
| ('333333', 'Enrolled', '2006-03-01', 'CAD' ),
 | ||
| ('333333', 'Disenrolled', '2006-03-01', 'CAD' ),
 | ||
| ('444444', 'Enrolled', '2006-03-01', 'CAD' ),
 | ||
| ('555555', 'Disenrolled', '2006-03-01', 'CAD' ),
 | ||
| ('555555', 'Enrolled', '2006-07-21', 'CAD' ),
 | ||
| ('555555', 'Disenrolled', '2006-03-01', 'CHF' ),
 | ||
| ('666666', 'Enrolled', '2006-02-09', 'CAD' ),
 | ||
| ('666666', 'Enrolled', '2006-05-12', 'CHF' ),
 | ||
| ('666666', 'Disenrolled', '2006-06-01', 'CAD' )|
 | ||
| CREATE FUNCTION bug21493(paramMember VARCHAR(15)) RETURNS varchar(45)
 | ||
| BEGIN
 | ||
| DECLARE tracks VARCHAR(45);
 | ||
| SELECT GROUP_CONCAT(Track SEPARATOR ', ') INTO tracks FROM t4
 | ||
| WHERE Member_ID=paramMember AND Action='Enrolled' AND 
 | ||
| (Track,Action_Date) IN (SELECT Track, MAX(Action_Date) FROM t4
 | ||
| WHERE Member_ID=paramMember GROUP BY Track);
 | ||
| RETURN tracks;
 | ||
| END|
 | ||
| SELECT bug21493('111111')|
 | ||
| bug21493('111111')
 | ||
| NULL
 | ||
| SELECT bug21493('222222')|
 | ||
| bug21493('222222')
 | ||
| CAD
 | ||
| SELECT bug21493(Member_ID) FROM t3|
 | ||
| bug21493(Member_ID)
 | ||
| NULL
 | ||
| CAD
 | ||
| CAD
 | ||
| CAD
 | ||
| CAD
 | ||
| CHF
 | ||
| DROP FUNCTION bug21493|
 | ||
| DROP TABLE t3,t4|
 | ||
| create table table_20028 (i int)|
 | ||
| SET @save_sql_mode=@@sql_mode|
 | ||
| SET sql_mode=''|
 | ||
| create function func_20028_a() returns integer
 | ||
| begin
 | ||
| declare temp integer;
 | ||
| select i into temp from table_20028 limit 1;
 | ||
| return ifnull(temp, 0);
 | ||
| end|
 | ||
| create function func_20028_b() returns integer
 | ||
| begin
 | ||
| return func_20028_a();
 | ||
| end|
 | ||
| create function func_20028_c() returns integer
 | ||
| begin
 | ||
| declare div_zero integer;
 | ||
| set SQL_MODE='TRADITIONAL';
 | ||
| select 1/0 into div_zero;
 | ||
| return div_zero;
 | ||
| end|
 | ||
| create procedure proc_20028_a()
 | ||
| begin
 | ||
| declare temp integer;
 | ||
| select i into temp from table_20028 limit 1;
 | ||
| end|
 | ||
| create procedure proc_20028_b()
 | ||
| begin
 | ||
| call proc_20028_a();
 | ||
| end|
 | ||
| create procedure proc_20028_c()
 | ||
| begin
 | ||
| declare div_zero integer;
 | ||
| set SQL_MODE='TRADITIONAL';
 | ||
| select 1/0 into div_zero;
 | ||
| end|
 | ||
| select func_20028_a()|
 | ||
| func_20028_a()
 | ||
| 0
 | ||
| select func_20028_b()|
 | ||
| func_20028_b()
 | ||
| 0
 | ||
| select func_20028_c()|
 | ||
| ERROR 22012: Division by 0
 | ||
| call proc_20028_a()|
 | ||
| Warnings:
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| call proc_20028_b()|
 | ||
| Warnings:
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| call proc_20028_c()|
 | ||
| ERROR 22012: Division by 0
 | ||
| SET sql_mode='TRADITIONAL'|
 | ||
| drop function func_20028_a|
 | ||
| drop function func_20028_b|
 | ||
| drop function func_20028_c|
 | ||
| drop procedure proc_20028_a|
 | ||
| drop procedure proc_20028_b|
 | ||
| drop procedure proc_20028_c|
 | ||
| create function func_20028_a() returns integer
 | ||
| begin
 | ||
| declare temp integer;
 | ||
| select i into temp from table_20028 limit 1;
 | ||
| return ifnull(temp, 0);
 | ||
| end|
 | ||
| create function func_20028_b() returns integer
 | ||
| begin
 | ||
| return func_20028_a();
 | ||
| end|
 | ||
| create function func_20028_c() returns integer
 | ||
| begin
 | ||
| declare div_zero integer;
 | ||
| set SQL_MODE='';
 | ||
| select 1/0 into div_zero;
 | ||
| return div_zero;
 | ||
| end|
 | ||
| create procedure proc_20028_a()
 | ||
| begin
 | ||
| declare temp integer;
 | ||
| select i into temp from table_20028 limit 1;
 | ||
| end|
 | ||
| create procedure proc_20028_b()
 | ||
| begin
 | ||
| call proc_20028_a();
 | ||
| end|
 | ||
| create procedure proc_20028_c()
 | ||
| begin
 | ||
| declare div_zero integer;
 | ||
| set SQL_MODE='';
 | ||
| select 1/0 into div_zero;
 | ||
| end|
 | ||
| select func_20028_a()|
 | ||
| func_20028_a()
 | ||
| 0
 | ||
| select func_20028_b()|
 | ||
| func_20028_b()
 | ||
| 0
 | ||
| select func_20028_c()|
 | ||
| func_20028_c()
 | ||
| NULL
 | ||
| call proc_20028_a()|
 | ||
| Warnings:
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| call proc_20028_b()|
 | ||
| Warnings:
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| call proc_20028_c()|
 | ||
| SET @@sql_mode=@save_sql_mode|
 | ||
| drop function func_20028_a|
 | ||
| drop function func_20028_b|
 | ||
| drop function func_20028_c|
 | ||
| drop procedure proc_20028_a|
 | ||
| drop procedure proc_20028_b|
 | ||
| drop procedure proc_20028_c|
 | ||
| drop table table_20028|
 | ||
| create procedure proc_21462_a()
 | ||
| begin
 | ||
| select "Called A";
 | ||
| end|
 | ||
| create procedure proc_21462_b(x int)
 | ||
| begin
 | ||
| select "Called B";
 | ||
| end|
 | ||
| call proc_21462_a|
 | ||
| Called A
 | ||
| Called A
 | ||
| call proc_21462_a()|
 | ||
| Called A
 | ||
| Called A
 | ||
| call proc_21462_a(1)|
 | ||
| ERROR 42000: Incorrect number of arguments for PROCEDURE test.proc_21462_a; expected 0, got 1
 | ||
| call proc_21462_b|
 | ||
| ERROR 42000: Incorrect number of arguments for PROCEDURE test.proc_21462_b; expected 1, got 0
 | ||
| call proc_21462_b()|
 | ||
| ERROR 42000: Incorrect number of arguments for PROCEDURE test.proc_21462_b; expected 1, got 0
 | ||
| call proc_21462_b(1)|
 | ||
| Called B
 | ||
| Called B
 | ||
| drop procedure proc_21462_a|
 | ||
| drop procedure proc_21462_b|
 | ||
| create table t3 (s1 int)|
 | ||
| create procedure proc_bug19733()
 | ||
| begin
 | ||
| declare v int default 0;
 | ||
| while v < 100 do
 | ||
| create index i on t3 (s1);
 | ||
| drop index i on t3;
 | ||
| set v = v + 1;
 | ||
| end while;
 | ||
| end|
 | ||
| call proc_bug19733()|
 | ||
| call proc_bug19733()|
 | ||
| call proc_bug19733()|
 | ||
| drop procedure proc_bug19733|
 | ||
| drop table t3|
 | ||
| CREATE TABLE t3 (t3_id INT)|
 | ||
| INSERT INTO t3 VALUES (0)|
 | ||
| INSERT INTO t3 VALUES (1)|
 | ||
| CREATE TABLE t4 (t4_id INT)|
 | ||
| INSERT INTO t4 VALUES (2)|
 | ||
| CREATE VIEW v1 AS
 | ||
| SELECT t3.t3_id, t4.t4_id
 | ||
| FROM t3 JOIN t4 ON t3.t3_id = 0|
 | ||
| CREATE VIEW v2 AS
 | ||
| SELECT t3.t3_id AS t3_id_1, v1.t3_id AS t3_id_2, v1.t4_id
 | ||
| FROM t3 LEFT JOIN v1 ON t3.t3_id = 0|
 | ||
| CREATE PROCEDURE p1() SELECT * FROM v2|
 | ||
| CALL p1()|
 | ||
| t3_id_1	t3_id_2	t4_id
 | ||
| 0	0	2
 | ||
| 1	NULL	NULL
 | ||
| CALL p1()|
 | ||
| t3_id_1	t3_id_2	t4_id
 | ||
| 0	0	2
 | ||
| 1	NULL	NULL
 | ||
| DROP PROCEDURE p1|
 | ||
| DROP VIEW v1, v2|
 | ||
| DROP TABLE t3, t4|
 | ||
| End of 5.0 tests
 | ||
| Begin of 5.1 tests
 | ||
| create function pi() returns varchar(50)
 | ||
| return "pie, my favorite desert.";
 | ||
| Warnings:
 | ||
| Note	1585	This function 'pi' has the same name as a native function
 | ||
| SET @save_sql_mode=@@sql_mode;
 | ||
| SET SQL_MODE='IGNORE_SPACE';
 | ||
| select pi(), pi ();
 | ||
| pi()	pi ()
 | ||
| 3.141593	3.141593
 | ||
| select test.pi(), test.pi ();
 | ||
| test.pi()	test.pi ()
 | ||
| pie, my favorite desert.	pie, my favorite desert.
 | ||
| SET SQL_MODE='';
 | ||
| select pi(), pi ();
 | ||
| pi()	pi ()
 | ||
| 3.141593	3.141593
 | ||
| select test.pi(), test.pi ();
 | ||
| test.pi()	test.pi ()
 | ||
| pie, my favorite desert.	pie, my favorite desert.
 | ||
| SET @@sql_mode=@save_sql_mode;
 | ||
| drop function pi;
 | ||
| create database nowhere;
 | ||
| use nowhere;
 | ||
| drop database nowhere;
 | ||
| SET @save_sql_mode=@@sql_mode;
 | ||
| SET SQL_MODE='IGNORE_SPACE';
 | ||
| select database(), database ();
 | ||
| database()	database ()
 | ||
| NULL	NULL
 | ||
| select current_user(), current_user ();
 | ||
| current_user()	current_user ()
 | ||
| root@localhost	root@localhost
 | ||
| select md5("aaa"), md5 ("aaa");
 | ||
| md5("aaa")	md5 ("aaa")
 | ||
| 47bce5c74f589f4867dbd57e9ca9f808	47bce5c74f589f4867dbd57e9ca9f808
 | ||
| SET SQL_MODE='';
 | ||
| select database(), database ();
 | ||
| database()	database ()
 | ||
| NULL	NULL
 | ||
| select current_user(), current_user ();
 | ||
| current_user()	current_user ()
 | ||
| root@localhost	root@localhost
 | ||
| select md5("aaa"), md5 ("aaa");
 | ||
| md5("aaa")	md5 ("aaa")
 | ||
| 47bce5c74f589f4867dbd57e9ca9f808	47bce5c74f589f4867dbd57e9ca9f808
 | ||
| use test;
 | ||
| create function `database`() returns varchar(50)
 | ||
| return "Stored function database";
 | ||
| Warnings:
 | ||
| Note	1585	This function 'database' has the same name as a native function
 | ||
| create function `current_user`() returns varchar(50)
 | ||
| return "Stored function current_user";
 | ||
| Warnings:
 | ||
| Note	1585	This function 'current_user' has the same name as a native function
 | ||
| create function md5(x varchar(50)) returns varchar(50)
 | ||
| return "Stored function md5";
 | ||
| Warnings:
 | ||
| Note	1585	This function 'md5' has the same name as a native function
 | ||
| SET SQL_MODE='IGNORE_SPACE';
 | ||
| select database(), database ();
 | ||
| database()	database ()
 | ||
| test	test
 | ||
| select current_user(), current_user ();
 | ||
| current_user()	current_user ()
 | ||
| root@localhost	root@localhost
 | ||
| select md5("aaa"), md5 ("aaa");
 | ||
| md5("aaa")	md5 ("aaa")
 | ||
| 47bce5c74f589f4867dbd57e9ca9f808	47bce5c74f589f4867dbd57e9ca9f808
 | ||
| select test.database(), test.database ();
 | ||
| test.database()	test.database ()
 | ||
| Stored function database	Stored function database
 | ||
| select test.current_user(), test.current_user ();
 | ||
| test.current_user()	test.current_user ()
 | ||
| Stored function current_user	Stored function current_user
 | ||
| select test.md5("aaa"), test.md5 ("aaa");
 | ||
| test.md5("aaa")	test.md5 ("aaa")
 | ||
| Stored function md5	Stored function md5
 | ||
| SET SQL_MODE='';
 | ||
| select database(), database ();
 | ||
| database()	database ()
 | ||
| test	test
 | ||
| select current_user(), current_user ();
 | ||
| current_user()	current_user ()
 | ||
| root@localhost	root@localhost
 | ||
| select md5("aaa"), md5 ("aaa");
 | ||
| md5("aaa")	md5 ("aaa")
 | ||
| 47bce5c74f589f4867dbd57e9ca9f808	47bce5c74f589f4867dbd57e9ca9f808
 | ||
| select test.database(), test.database ();
 | ||
| test.database()	test.database ()
 | ||
| Stored function database	Stored function database
 | ||
| select test.current_user(), test.current_user ();
 | ||
| test.current_user()	test.current_user ()
 | ||
| Stored function current_user	Stored function current_user
 | ||
| select test.md5("aaa"), test.md5 ("aaa");
 | ||
| test.md5("aaa")	test.md5 ("aaa")
 | ||
| Stored function md5	Stored function md5
 | ||
| SET @@sql_mode=@save_sql_mode;
 | ||
| drop function test.database;
 | ||
| drop function test.current_user;
 | ||
| drop function md5;
 | ||
| use test;
 | ||
| End of 5.1 tests
 | ||
| CREATE TABLE bug23760 (
 | ||
| id INT NOT NULL AUTO_INCREMENT ,
 | ||
| num INT NOT NULL ,
 | ||
| PRIMARY KEY ( id ) 
 | ||
| )|
 | ||
| CREATE TABLE bug23760_log (
 | ||
| id INT NOT NULL AUTO_INCREMENT ,
 | ||
| reason VARCHAR(50)NULL ,
 | ||
| ammount INT NOT NULL ,
 | ||
| PRIMARY KEY ( id ) 
 | ||
| )|
 | ||
| CREATE PROCEDURE bug23760_update_log(r Varchar(50), a INT)
 | ||
| BEGIN
 | ||
| INSERT INTO bug23760_log (reason, ammount) VALUES(r, a);
 | ||
| END|
 | ||
| CREATE PROCEDURE bug23760_test_row_count()
 | ||
| BEGIN
 | ||
| UPDATE bug23760 SET num = num + 1;
 | ||
| CALL bug23760_update_log('Test is working', ROW_COUNT());
 | ||
| UPDATE bug23760 SET num = num - 1;
 | ||
| END|
 | ||
| CREATE PROCEDURE bug23760_test_row_count2(level INT)
 | ||
| BEGIN
 | ||
| IF level THEN
 | ||
| UPDATE bug23760 SET num = num + 1;
 | ||
| CALL bug23760_update_log('Test2 is working', ROW_COUNT());
 | ||
| CALL bug23760_test_row_count2(level - 1);
 | ||
| END IF;
 | ||
| END|
 | ||
| CREATE FUNCTION bug23760_rc_test(in_var INT) RETURNS INT RETURN in_var|
 | ||
| INSERT INTO bug23760 (num) VALUES (0), (1), (1), (2), (3), (5), (8)|
 | ||
| SELECT ROW_COUNT()|
 | ||
| ROW_COUNT()
 | ||
| 7
 | ||
| CALL bug23760_test_row_count()|
 | ||
| SELECT * FROM bug23760_log ORDER BY id|
 | ||
| id	reason	ammount
 | ||
| 1	Test is working	7
 | ||
| SET @save_max_sp_recursion= @@max_sp_recursion_depth|
 | ||
| SELECT @save_max_sp_recursion|
 | ||
| @save_max_sp_recursion
 | ||
| 0
 | ||
| SET max_sp_recursion_depth= 5|
 | ||
| SELECT @@max_sp_recursion_depth|
 | ||
| @@max_sp_recursion_depth
 | ||
| 5
 | ||
| CALL bug23760_test_row_count2(2)|
 | ||
| SELECT ROW_COUNT()|
 | ||
| ROW_COUNT()
 | ||
| 16
 | ||
| SELECT * FROM bug23760_log ORDER BY id|
 | ||
| id	reason	ammount
 | ||
| 1	Test is working	7
 | ||
| 2	Test2 is working	7
 | ||
| 3	Test2 is working	7
 | ||
| SELECT * FROM bug23760 ORDER by ID|
 | ||
| id	num
 | ||
| 1	2
 | ||
| 2	3
 | ||
| 3	3
 | ||
| 4	4
 | ||
| 5	5
 | ||
| 6	7
 | ||
| 7	10
 | ||
| SET max_sp_recursion_depth= @save_max_sp_recursion|
 | ||
| SELECT bug23760_rc_test(123)|
 | ||
| bug23760_rc_test(123)
 | ||
| 123
 | ||
| INSERT INTO bug23760 (num) VALUES (13), (21), (34), (55)|
 | ||
| SELECT bug23760_rc_test(ROW_COUNT())|
 | ||
| bug23760_rc_test(ROW_COUNT())
 | ||
| 4
 | ||
| DROP TABLE bug23760, bug23760_log|
 | ||
| DROP PROCEDURE bug23760_update_log|
 | ||
| DROP PROCEDURE bug23760_test_row_count|
 | ||
| DROP PROCEDURE bug23760_test_row_count2|
 | ||
| DROP FUNCTION bug23760_rc_test|
 | ||
| CREATE TABLE t3(c1 ENUM('abc'))|
 | ||
| INSERT INTO t3 VALUES('abc')|
 | ||
| CREATE PROCEDURE bug24117()
 | ||
| BEGIN
 | ||
| DECLARE t3c1 ENUM('abc');
 | ||
| DECLARE mycursor CURSOR FOR SELECT c1 FROM t3;
 | ||
| OPEN mycursor;
 | ||
| FLUSH TABLES;
 | ||
| FETCH mycursor INTO t3c1;
 | ||
| CLOSE mycursor;
 | ||
| END|
 | ||
| CALL bug24117()|
 | ||
| DROP PROCEDURE bug24117|
 | ||
| DROP TABLE t3|
 | ||
| create function func_8407_a() returns int
 | ||
| begin
 | ||
| declare x int;
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| end;
 | ||
| select 1 from no_such_view limit 1 into x;
 | ||
| return x;
 | ||
| end|
 | ||
| create function func_8407_b() returns int
 | ||
| begin
 | ||
| declare x int default 0;
 | ||
| declare continue handler for sqlstate '42S02'
 | ||
|   begin
 | ||
| set x:= x+1000;
 | ||
| end;
 | ||
| case (select 1 from no_such_view limit 1)
 | ||
| when 1 then set x:= x+1;
 | ||
| when 2 then set x:= x+2;
 | ||
| else set x:= x+100;
 | ||
| end case;
 | ||
| set x:=x + 500;
 | ||
| return x;
 | ||
| end|
 | ||
| select func_8407_a()|
 | ||
| func_8407_a()
 | ||
| NULL
 | ||
| select func_8407_b()|
 | ||
| func_8407_b()
 | ||
| 1500
 | ||
| drop function func_8407_a|
 | ||
| drop function func_8407_b|
 | ||
| create table table_26503(a int unique)|
 | ||
| create procedure proc_26503_ok_1(v int)
 | ||
| begin
 | ||
| declare i int default 5;
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| select 'caught something';
 | ||
| retry:
 | ||
| while i > 0 do
 | ||
| begin
 | ||
| set i = i - 1;
 | ||
| select 'looping', i;
 | ||
| iterate retry;
 | ||
| select 'dead code';
 | ||
| end;
 | ||
| end while retry;
 | ||
| select 'leaving handler';
 | ||
| end;
 | ||
| select 'do something';
 | ||
| insert into table_26503 values (v);
 | ||
| select 'do something again';
 | ||
| insert into table_26503 values (v);
 | ||
| end|
 | ||
| create procedure proc_26503_ok_2(v int)
 | ||
| begin
 | ||
| declare i int default 5;
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| select 'caught something';
 | ||
| retry:
 | ||
| while i > 0 do
 | ||
| begin
 | ||
| set i = i - 1;
 | ||
| select 'looping', i;
 | ||
| leave retry;
 | ||
| select 'dead code';
 | ||
| end;
 | ||
| end while;
 | ||
| select 'leaving handler';
 | ||
| end;
 | ||
| select 'do something';
 | ||
| insert into table_26503 values (v);
 | ||
| select 'do something again';
 | ||
| insert into table_26503 values (v);
 | ||
| end|
 | ||
| create procedure proc_26503_ok_3(v int)
 | ||
| begin
 | ||
| declare i int default 5;
 | ||
| retry:
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| select 'caught something';
 | ||
| retry:
 | ||
| while i > 0 do
 | ||
| begin
 | ||
| set i = i - 1;
 | ||
| select 'looping', i;
 | ||
| iterate retry;
 | ||
| select 'dead code';
 | ||
| end;
 | ||
| end while retry;
 | ||
| select 'leaving handler';
 | ||
| end;
 | ||
| select 'do something';
 | ||
| insert into table_26503 values (v);
 | ||
| select 'do something again';
 | ||
| insert into table_26503 values (v);
 | ||
| end;
 | ||
| end|
 | ||
| create procedure proc_26503_ok_4(v int)
 | ||
| begin
 | ||
| declare i int default 5;
 | ||
| retry:
 | ||
| begin
 | ||
| declare continue handler for sqlexception
 | ||
| begin
 | ||
| select 'caught something';
 | ||
| retry:
 | ||
| while i > 0 do
 | ||
| begin
 | ||
| set i = i - 1;
 | ||
| select 'looping', i;
 | ||
| leave retry;
 | ||
| select 'dead code';
 | ||
| end;
 | ||
| end while;
 | ||
| select 'leaving handler';
 | ||
| end;
 | ||
| select 'do something';
 | ||
| insert into table_26503 values (v);
 | ||
| select 'do something again';
 | ||
| insert into table_26503 values (v);
 | ||
| end;
 | ||
| end|
 | ||
| call proc_26503_ok_1(1)|
 | ||
| do something
 | ||
| do something
 | ||
| do something again
 | ||
| do something again
 | ||
| caught something
 | ||
| caught something
 | ||
| looping	i
 | ||
| looping	4
 | ||
| looping	i
 | ||
| looping	3
 | ||
| looping	i
 | ||
| looping	2
 | ||
| looping	i
 | ||
| looping	1
 | ||
| looping	i
 | ||
| looping	0
 | ||
| leaving handler
 | ||
| leaving handler
 | ||
| call proc_26503_ok_2(2)|
 | ||
| do something
 | ||
| do something
 | ||
| do something again
 | ||
| do something again
 | ||
| caught something
 | ||
| caught something
 | ||
| looping	i
 | ||
| looping	4
 | ||
| leaving handler
 | ||
| leaving handler
 | ||
| call proc_26503_ok_3(3)|
 | ||
| do something
 | ||
| do something
 | ||
| do something again
 | ||
| do something again
 | ||
| caught something
 | ||
| caught something
 | ||
| looping	i
 | ||
| looping	4
 | ||
| looping	i
 | ||
| looping	3
 | ||
| looping	i
 | ||
| looping	2
 | ||
| looping	i
 | ||
| looping	1
 | ||
| looping	i
 | ||
| looping	0
 | ||
| leaving handler
 | ||
| leaving handler
 | ||
| call proc_26503_ok_4(4)|
 | ||
| do something
 | ||
| do something
 | ||
| do something again
 | ||
| do something again
 | ||
| caught something
 | ||
| caught something
 | ||
| looping	i
 | ||
| looping	4
 | ||
| leaving handler
 | ||
| leaving handler
 | ||
| drop table table_26503|
 | ||
| drop procedure proc_26503_ok_1|
 | ||
| drop procedure proc_26503_ok_2|
 | ||
| drop procedure proc_26503_ok_3|
 | ||
| drop procedure proc_26503_ok_4|
 | ||
| CREATE FUNCTION bug25373(p1 INTEGER) RETURNS INTEGER
 | ||
| LANGUAGE SQL DETERMINISTIC
 | ||
| RETURN p1;|
 | ||
| CREATE TABLE t3 (f1 INT, f2 FLOAT)|
 | ||
| INSERT INTO t3 VALUES (1, 3.4), (1, 2), (1, 0.9), (2, 8), (2, 7)|
 | ||
| SELECT SUM(f2), bug25373(f1) FROM t3 GROUP BY bug25373(f1) WITH ROLLUP|
 | ||
| SUM(f2)	bug25373(f1)
 | ||
| 6.300000071525574	1
 | ||
| 15	2
 | ||
| 21.300000071525574	NULL
 | ||
| DROP FUNCTION bug25373|
 | ||
| DROP TABLE t3|
 | ||
| CREATE DATABASE mysqltest1|
 | ||
| CREATE DATABASE mysqltest2|
 | ||
| CREATE PROCEDURE mysqltest1.p1()
 | ||
| DROP DATABASE mysqltest2|
 | ||
| use mysqltest2|
 | ||
| CALL mysqltest1.p1()|
 | ||
| Warnings:
 | ||
| Note	1049	Unknown database 'mysqltest2'
 | ||
| SELECT DATABASE()|
 | ||
| DATABASE()
 | ||
| NULL
 | ||
| DROP DATABASE mysqltest1|
 | ||
| use test|
 | ||
| create function bug20777(f1 bigint unsigned) returns bigint unsigned
 | ||
| begin
 | ||
| set f1 = (f1 - 10); set f1 = (f1 + 10);
 | ||
| return f1;
 | ||
| end|
 | ||
| select bug20777(9223372036854775803) as '9223372036854775803   2**63-5';
 | ||
| 9223372036854775803   2**63-5
 | ||
| 9223372036854775803
 | ||
| select bug20777(9223372036854775804) as '9223372036854775804   2**63-4';
 | ||
| 9223372036854775804   2**63-4
 | ||
| 9223372036854775804
 | ||
| select bug20777(9223372036854775805) as '9223372036854775805   2**63-3';
 | ||
| 9223372036854775805   2**63-3
 | ||
| 9223372036854775805
 | ||
| select bug20777(9223372036854775806) as '9223372036854775806   2**63-2';
 | ||
| 9223372036854775806   2**63-2
 | ||
| 9223372036854775806
 | ||
| select bug20777(9223372036854775807) as '9223372036854775807   2**63-1';
 | ||
| 9223372036854775807   2**63-1
 | ||
| 9223372036854775807
 | ||
| select bug20777(9223372036854775808) as '9223372036854775808   2**63+0';
 | ||
| 9223372036854775808   2**63+0
 | ||
| 9223372036854775808
 | ||
| select bug20777(9223372036854775809) as '9223372036854775809   2**63+1';
 | ||
| 9223372036854775809   2**63+1
 | ||
| 9223372036854775809
 | ||
| select bug20777(9223372036854775810) as '9223372036854775810   2**63+2';
 | ||
| 9223372036854775810   2**63+2
 | ||
| 9223372036854775810
 | ||
| select bug20777(-9223372036854775808) as 'lower bounds signed bigint';
 | ||
| ERROR 22003: BIGINT UNSIGNED value is out of range in 'f1@0 - 10'
 | ||
| select bug20777(9223372036854775807) as 'upper bounds signed bigint';
 | ||
| upper bounds signed bigint
 | ||
| 9223372036854775807
 | ||
| select bug20777(0) as 'lower bounds unsigned bigint';
 | ||
| ERROR 22003: BIGINT UNSIGNED value is out of range in 'f1@0 - 10'
 | ||
| select bug20777(18446744073709551615) as 'upper bounds unsigned bigint';
 | ||
| upper bounds unsigned bigint
 | ||
| 18446744073709551615
 | ||
| select bug20777(18446744073709551616) as 'upper bounds unsigned bigint + 1';
 | ||
| upper bounds unsigned bigint + 1
 | ||
| 18446744073709551615
 | ||
| Warnings:
 | ||
| Warning	1264	Out of range value for column 'f1' at row 1
 | ||
| select bug20777(-1) as 'lower bounds unsigned bigint - 1';
 | ||
| ERROR 22003: BIGINT UNSIGNED value is out of range in 'f1@0 - 10'
 | ||
| create table examplebug20777 as select 
 | ||
| 0 as 'i',
 | ||
| bug20777(9223372036854775806) as '2**63-2',
 | ||
| bug20777(9223372036854775807) as '2**63-1',
 | ||
| bug20777(9223372036854775808) as '2**63',
 | ||
| bug20777(9223372036854775809) as '2**63+1',
 | ||
| bug20777(18446744073709551614) as '2**64-2',
 | ||
| bug20777(18446744073709551615) as '2**64-1', 
 | ||
| bug20777(18446744073709551616) as '2**64';
 | ||
| Warnings:
 | ||
| Warning	1264	Out of range value for column 'f1' at row 1
 | ||
| insert into examplebug20777 values (1, 9223372036854775806, 9223372036854775807, 223372036854775808, 9223372036854775809, 18446744073709551614, 18446744073709551615, 8446744073709551616);
 | ||
| show create table examplebug20777;
 | ||
| Table	Create Table
 | ||
| examplebug20777	CREATE TABLE `examplebug20777` (
 | ||
|   `i` int(1) NOT NULL,
 | ||
|   `2**63-2` bigint(20) unsigned DEFAULT NULL,
 | ||
|   `2**63-1` bigint(20) unsigned DEFAULT NULL,
 | ||
|   `2**63` bigint(20) unsigned DEFAULT NULL,
 | ||
|   `2**63+1` bigint(20) unsigned DEFAULT NULL,
 | ||
|   `2**64-2` bigint(20) unsigned DEFAULT NULL,
 | ||
|   `2**64-1` bigint(20) unsigned DEFAULT NULL,
 | ||
|   `2**64` bigint(20) unsigned DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| select * from examplebug20777 order by i;
 | ||
| i	2**63-2	2**63-1	2**63	2**63+1	2**64-2	2**64-1	2**64
 | ||
| 0	9223372036854775806	9223372036854775807	9223372036854775808	9223372036854775809	18446744073709551614	18446744073709551615	18446744073709551615
 | ||
| 1	9223372036854775806	9223372036854775807	223372036854775808	9223372036854775809	18446744073709551614	18446744073709551615	8446744073709551616
 | ||
| drop table examplebug20777;
 | ||
| select bug20777(18446744073709551613)+1;
 | ||
| bug20777(18446744073709551613)+1
 | ||
| 18446744073709551614
 | ||
| drop function bug20777;
 | ||
| CREATE FUNCTION bug5274_f1(p1 CHAR) RETURNS CHAR
 | ||
| RETURN CONCAT(p1, p1)|
 | ||
| CREATE FUNCTION bug5274_f2() RETURNS CHAR
 | ||
| BEGIN
 | ||
| DECLARE v1 INT DEFAULT 0;
 | ||
| DECLARE v2 CHAR DEFAULT 'x';
 | ||
| WHILE v1 < 30 DO
 | ||
| SET v1 = v1 + 1;
 | ||
| SET v2 = bug5274_f1(v2);
 | ||
| END WHILE;
 | ||
| RETURN v2;
 | ||
| END|
 | ||
| SELECT bug5274_f2()|
 | ||
| bug5274_f2()
 | ||
| x
 | ||
| DROP FUNCTION bug5274_f1|
 | ||
| DROP FUNCTION bug5274_f2|
 | ||
| create procedure proc_21513()`my_label`:BEGIN END|
 | ||
| show create procedure proc_21513|
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| proc_21513		CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_21513`()
 | ||
| `my_label`:BEGIN END	utf8mb3	utf8mb3_uca1400_ai_ci	utf8mb4_uca1400_ai_ci
 | ||
| drop procedure proc_21513|
 | ||
| End of 5.0 tests.
 | ||
| drop table t1,t2;
 | ||
| CREATE TABLE t1 (a int auto_increment primary key) engine=MyISAM;
 | ||
| CREATE TABLE t2 (a int auto_increment primary key, b int) engine=innodb;
 | ||
| set @a=0;
 | ||
| CREATE function bug27354() RETURNS int not deterministic
 | ||
| begin
 | ||
| insert into t1 values (null);
 | ||
| set @a=@a+1;
 | ||
| return @a;
 | ||
| end|
 | ||
| update t2 set b=1 where a=bug27354();
 | ||
| select count(t_1.a),count(t_2.a) from t1 as t_1, t2 as t_2 /* must be 0,0 */;
 | ||
| count(t_1.a)	count(t_2.a)
 | ||
| 0	0
 | ||
| insert into t2 values (1,1),(2,2),(3,3);
 | ||
| update t2 set b=-b where a=bug27354();
 | ||
| select * from t2 /* must return 1,-1 ... */;
 | ||
| a	b
 | ||
| 1	-1
 | ||
| 2	-2
 | ||
| 3	-3
 | ||
| select count(*) from t1 /* must be 3 */;
 | ||
| count(*)
 | ||
| 3
 | ||
| drop table t1,t2;
 | ||
| drop function   bug27354;
 | ||
| CREATE TABLE t1 (a INT);
 | ||
| INSERT INTO t1 VALUES (1),(2);
 | ||
| CREATE FUNCTION metered(a INT) RETURNS INT RETURN 12;
 | ||
| CREATE VIEW v1 AS SELECT test.metered(a) as metered FROM t1;
 | ||
| SHOW CREATE VIEW v1;
 | ||
| View	Create View	character_set_client	collation_connection
 | ||
| v1	CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `v1` AS select `test`.`metered`(`t1`.`a`) AS `metered` from `t1`	utf8mb3	utf8mb3_uca1400_ai_ci
 | ||
| DROP VIEW v1;
 | ||
| DROP FUNCTION metered;
 | ||
| DROP TABLE t1;
 | ||
| SET @p1_p2_cnt= 2;
 | ||
| CREATE TABLE t1 (c1 INT);
 | ||
| CREATE VIEW v1 AS SELECT * FROM t1;
 | ||
| PREPARE s1 FROM 'SELECT c1 FROM v1';
 | ||
| EXECUTE s1;
 | ||
| c1
 | ||
| EXECUTE s1;
 | ||
| c1
 | ||
| CREATE PROCEDURE p1(IN loops BIGINT(19) UNSIGNED)
 | ||
| BEGIN
 | ||
| WHILE loops > 0 DO
 | ||
| SELECT c1 FROM v1;
 | ||
| SET loops = loops - 1;
 | ||
| END WHILE;
 | ||
| END|
 | ||
| CREATE PROCEDURE p2(IN loops BIGINT(19) UNSIGNED)
 | ||
| BEGIN
 | ||
| WHILE loops > 0 DO
 | ||
| SELECT c1 FROM v1;
 | ||
| CALL p1(@p1_p2_cnt);
 | ||
| SET loops = loops - 1;
 | ||
| END WHILE;
 | ||
| END|
 | ||
| CREATE FUNCTION f1(loops INT UNSIGNED)
 | ||
| RETURNS INT
 | ||
| BEGIN
 | ||
| DECLARE tmp INT;
 | ||
| WHILE loops > 0 DO
 | ||
| SELECT c1 INTO tmp FROM v1;
 | ||
| SET loops = loops - 1;
 | ||
| END WHILE;
 | ||
| RETURN loops;
 | ||
| END|
 | ||
| CALL p1(2);
 | ||
| c1
 | ||
| c1
 | ||
| CALL p2(2);
 | ||
| c1
 | ||
| c1
 | ||
| c1
 | ||
| c1
 | ||
| c1
 | ||
| c1
 | ||
| SELECT f1(2);
 | ||
| f1(2)
 | ||
| 0
 | ||
| PREPARE s1 FROM 'SELECT f1(2)';
 | ||
| EXECUTE s1;
 | ||
| f1(2)
 | ||
| 0
 | ||
| EXECUTE s1;
 | ||
| f1(2)
 | ||
| 0
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP PROCEDURE p2;
 | ||
| DROP FUNCTION f1;
 | ||
| DROP VIEW v1;
 | ||
| DROP TABLE t1;
 | ||
| create database mysqltest_db1;
 | ||
| create procedure mysqltest_db1.sp_bug28551() begin end;
 | ||
| call mysqltest_db1.sp_bug28551();
 | ||
| show warnings;
 | ||
| Level	Code	Message
 | ||
| drop database mysqltest_db1;
 | ||
| create database mysqltest_db1;
 | ||
| use mysqltest_db1;
 | ||
| drop database mysqltest_db1;
 | ||
| create table test.t1 (id int);
 | ||
| insert into test.t1 (id) values (1);
 | ||
| create procedure test.sp_bug29050() begin select * from t1; end//
 | ||
| show warnings;
 | ||
| Level	Code	Message
 | ||
| call test.sp_bug29050();
 | ||
| id
 | ||
| 1
 | ||
| show warnings;
 | ||
| Level	Code	Message
 | ||
| use test;
 | ||
| drop procedure sp_bug29050;
 | ||
| drop table t1;
 | ||
| SET NAMES latin1;
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE <20><><EFBFBD> INT;
 | ||
| SELECT <20><><EFBFBD>;
 | ||
| END|
 | ||
| CALL p1();
 | ||
| <EFBFBD><EFBFBD><EFBFBD>
 | ||
| NULL
 | ||
| set @@character_set_client=@save_character_set_client;
 | ||
| set @@character_set_results=@save_character_set_client;
 | ||
| DROP PROCEDURE p1;
 | ||
| create procedure proc_25411_a()
 | ||
| begin
 | ||
| /* real comment */
 | ||
| select 1;
 | ||
| /*! select 2; */
 | ||
| select 3;
 | ||
| /*!00000 select 4; */
 | ||
| /*!999999 select 5; */
 | ||
| end
 | ||
| $$
 | ||
| create procedure proc_25411_b(
 | ||
| /* real comment */
 | ||
| /*! p1 int, */
 | ||
| /*!00000 p2 int */
 | ||
| /*!999999 ,p3 int */
 | ||
| )
 | ||
| begin
 | ||
| select p1, p2;
 | ||
| end
 | ||
| $$
 | ||
| create procedure proc_25411_c()
 | ||
| begin
 | ||
| select 1/*!,2*//*!00000,3*//*!999999,4*/;
 | ||
| select 1/*! ,2*//*!00000 ,3*//*!999999 ,4*/;
 | ||
| select 1/*!,2 *//*!00000,3 *//*!999999,4 */;
 | ||
| select 1/*! ,2 *//*!00000 ,3 *//*!999999 ,4 */;
 | ||
| select 1 /*!,2*/ /*!00000,3*/ /*!999999,4*/ ;
 | ||
| end
 | ||
| $$
 | ||
| show create procedure proc_25411_a;
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| proc_25411_a		CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_25411_a`()
 | ||
| begin
 | ||
| /* real comment */
 | ||
| select 1;
 | ||
|  select 2; 
 | ||
| select 3;
 | ||
|  select 4; 
 | ||
| 
 | ||
| end	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| call proc_25411_a();
 | ||
| 1
 | ||
| 1
 | ||
| 2
 | ||
| 2
 | ||
| 3
 | ||
| 3
 | ||
| 4
 | ||
| 4
 | ||
| show create procedure proc_25411_b;
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| proc_25411_b		CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_25411_b`(
 | ||
| /* real comment */
 | ||
|  p1 int, 
 | ||
|  p2 int 
 | ||
| 
 | ||
| )
 | ||
| begin
 | ||
| select p1, p2;
 | ||
| end	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| select name, param_list, body from mysql.proc where name like "%25411%" order by name;
 | ||
| name	param_list	body
 | ||
| proc_25411_a		begin
 | ||
| /* real comment */
 | ||
| select 1;
 | ||
|  select 2; 
 | ||
| select 3;
 | ||
|  select 4; 
 | ||
| 
 | ||
| end
 | ||
| proc_25411_b	
 | ||
| /* real comment */
 | ||
|  p1 int, 
 | ||
|  p2 int 
 | ||
| 
 | ||
| 	begin
 | ||
| select p1, p2;
 | ||
| end
 | ||
| proc_25411_c		begin
 | ||
| select 1,2,3;
 | ||
| select 1 ,2 ,3;
 | ||
| select 1,2 ,3 ;
 | ||
| select 1 ,2  ,3 ;
 | ||
| select 1 ,2 ,3  ;
 | ||
| end
 | ||
| call proc_25411_b(10, 20);
 | ||
| p1	p2
 | ||
| 10	20
 | ||
| show create procedure proc_25411_c;
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| proc_25411_c		CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_25411_c`()
 | ||
| begin
 | ||
| select 1,2,3;
 | ||
| select 1 ,2 ,3;
 | ||
| select 1,2 ,3 ;
 | ||
| select 1 ,2  ,3 ;
 | ||
| select 1 ,2 ,3  ;
 | ||
| end	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| call proc_25411_c();
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| 1	2	3
 | ||
| drop procedure proc_25411_a;
 | ||
| drop procedure proc_25411_b;
 | ||
| drop procedure proc_25411_c;
 | ||
| create procedure proc_26302()
 | ||
| select 1 /* testing */;
 | ||
| show create procedure proc_26302;
 | ||
| Procedure	sql_mode	Create Procedure	character_set_client	collation_connection	Database Collation
 | ||
| proc_26302		CREATE DEFINER=`root`@`localhost` PROCEDURE `proc_26302`()
 | ||
| select 1 /* testing */	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| select ROUTINE_NAME, ROUTINE_DEFINITION from information_schema.ROUTINES
 | ||
| where ROUTINE_NAME = "proc_26302";
 | ||
| ROUTINE_NAME	ROUTINE_DEFINITION
 | ||
| proc_26302	select 1 /* testing */
 | ||
| drop procedure proc_26302;
 | ||
| CREATE FUNCTION f1() RETURNS INT DETERMINISTIC RETURN 2;
 | ||
| CREATE FUNCTION f2(I INT) RETURNS INT DETERMINISTIC RETURN 3;
 | ||
| CREATE TABLE t1 (c1 INT, INDEX(c1));
 | ||
| INSERT INTO t1 VALUES (1), (2), (3), (4), (5);
 | ||
| CREATE VIEW v1 AS SELECT c1 FROM t1;
 | ||
| EXPLAIN SELECT * FROM t1 WHERE c1=1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	ref	c1	c1	5	const	1	Using index
 | ||
| EXPLAIN SELECT * FROM t1 WHERE c1=f1();
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	ref	c1	c1	5	const	1	Using where; Using index
 | ||
| EXPLAIN SELECT * FROM v1 WHERE c1=1;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	ref	c1	c1	5	const	1	Using index
 | ||
| EXPLAIN SELECT * FROM v1 WHERE c1=f1();
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	ref	c1	c1	5	const	1	Using where; Using index
 | ||
| EXPLAIN SELECT * FROM t1 WHERE c1=f2(10);
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	ref	c1	c1	5	const	1	Using where; Using index
 | ||
| EXPLAIN SELECT * FROM t1 WHERE c1=f2(c1);
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	index	NULL	c1	5	NULL	5	Using where; Using index
 | ||
| EXPLAIN SELECT * FROM t1 WHERE c1=f2(rand());
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t1	index	NULL	c1	5	NULL	5	Using where; Using index
 | ||
| DROP VIEW v1;
 | ||
| DROP FUNCTION f1;
 | ||
| DROP FUNCTION f2;
 | ||
| DROP TABLE t1;
 | ||
| create function f1()
 | ||
| returns int(11)
 | ||
| not deterministic
 | ||
| contains sql
 | ||
| sql security definer
 | ||
| comment ''
 | ||
| begin
 | ||
| declare x int(11);
 | ||
| set x=-1;
 | ||
| return x;
 | ||
| end|
 | ||
| create view v1 as select 1 as one, f1() as days;
 | ||
| connect  bug29408, localhost, root,,*NO-ONE*;
 | ||
| connection bug29408;
 | ||
| show create view test.v1;
 | ||
| View	Create View	character_set_client	collation_connection
 | ||
| v1	CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `test`.`v1` AS select 1 AS `one`,`f1`() AS `days`	latin1	latin1_swedish_ci
 | ||
| select column_name from information_schema.columns
 | ||
| where table_name='v1' and table_schema='test';
 | ||
| column_name
 | ||
| one
 | ||
| days
 | ||
| connection default;
 | ||
| disconnect bug29408;
 | ||
| drop view v1;
 | ||
| drop function f1;
 | ||
| 
 | ||
| # Bug#13675.
 | ||
| 
 | ||
| 
 | ||
| CREATE PROCEDURE p1(v DATETIME) CREATE TABLE t1 SELECT v;
 | ||
| CREATE PROCEDURE p2(v INT) CREATE TABLE t1 SELECT v;
 | ||
| 
 | ||
| CALL p1(NOW());
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `v` datetime DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| 
 | ||
| CALL p1('text');
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'v' at row 0
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `v` datetime DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| 
 | ||
| CALL p2(10);
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `v` int(11) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| 
 | ||
| CALL p2('text');
 | ||
| Warnings:
 | ||
| Warning	1366	Incorrect integer value: 'text' for column ``.``.`v` at row 0
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `v` int(11) DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| 
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP PROCEDURE p2;
 | ||
| 
 | ||
| #
 | ||
| # Bug#31035.
 | ||
| #
 | ||
| 
 | ||
| #
 | ||
| # - Prepare.
 | ||
| #
 | ||
| 
 | ||
| 
 | ||
| #
 | ||
| # - Create required objects.
 | ||
| #
 | ||
| 
 | ||
| CREATE TABLE t1(c1 INT);
 | ||
| 
 | ||
| INSERT INTO t1 VALUES (1), (2), (3);
 | ||
| 
 | ||
| CREATE FUNCTION f1()
 | ||
| RETURNS INT
 | ||
| NOT DETERMINISTIC
 | ||
| RETURN 1;
 | ||
| 
 | ||
| CREATE FUNCTION f2(p INT)
 | ||
| RETURNS INT
 | ||
| NOT DETERMINISTIC
 | ||
| RETURN 1;
 | ||
| 
 | ||
| CREATE FUNCTION f3()
 | ||
| RETURNS INT
 | ||
| DETERMINISTIC
 | ||
| RETURN 1;
 | ||
| 
 | ||
| CREATE FUNCTION f4(p INT)
 | ||
| RETURNS INT
 | ||
| DETERMINISTIC
 | ||
| RETURN 1;
 | ||
| 
 | ||
| #
 | ||
| # - Check.
 | ||
| #
 | ||
| 
 | ||
| SELECT f1() AS a FROM t1 GROUP BY a;
 | ||
| a
 | ||
| 1
 | ||
| 
 | ||
| SELECT f2(@a) AS a FROM t1 GROUP BY a;
 | ||
| a
 | ||
| 1
 | ||
| 
 | ||
| SELECT f3() AS a FROM t1 GROUP BY a;
 | ||
| a
 | ||
| 1
 | ||
| 
 | ||
| SELECT f4(0) AS a FROM t1 GROUP BY a;
 | ||
| a
 | ||
| 1
 | ||
| 
 | ||
| SELECT f4(@a) AS a FROM t1 GROUP BY a;
 | ||
| a
 | ||
| 1
 | ||
| 
 | ||
| #
 | ||
| # - Cleanup.
 | ||
| #
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| DROP FUNCTION f2;
 | ||
| DROP FUNCTION f3;
 | ||
| DROP FUNCTION f4;
 | ||
| 
 | ||
| #
 | ||
| # Bug#31191.
 | ||
| #
 | ||
| 
 | ||
| #
 | ||
| # - Prepare.
 | ||
| #
 | ||
| 
 | ||
| 
 | ||
| #
 | ||
| # - Create required objects.
 | ||
| #
 | ||
| 
 | ||
| CREATE TABLE t1 (
 | ||
| id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
 | ||
| barcode INT(8) UNSIGNED ZEROFILL nOT NULL,
 | ||
| PRIMARY KEY  (id),
 | ||
| UNIQUE KEY barcode (barcode)
 | ||
| );
 | ||
| 
 | ||
| INSERT INTO t1 (id, barcode) VALUES (1, 12345678);
 | ||
| INSERT INTO t1 (id, barcode) VALUES (2, 12345679);
 | ||
| 
 | ||
| CREATE TABLE test.t2 (
 | ||
| id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
 | ||
| barcode BIGINT(11) UNSIGNED ZEROFILL NOT NULL,
 | ||
| PRIMARY KEY  (id)
 | ||
| );
 | ||
| 
 | ||
| INSERT INTO test.t2 (id, barcode) VALUES (1, 12345106708);
 | ||
| INSERT INTO test.t2 (id, barcode) VALUES (2, 12345106709);
 | ||
| 
 | ||
| CREATE FUNCTION f1(p INT(8))
 | ||
| RETURNS BIGINT(11) UNSIGNED
 | ||
| READS SQL DATA
 | ||
| RETURN FLOOR(p/1000)*1000000 + 100000 + FLOOR((p MOD 1000)/10)*100 + (p MOD 10);
 | ||
| 
 | ||
| #
 | ||
| # - Check.
 | ||
| #
 | ||
| 
 | ||
| SELECT DISTINCT t1.barcode, f1(t1.barcode)
 | ||
| FROM t1
 | ||
| INNER JOIN t2
 | ||
| ON f1(t1.barcode) = t2.barcode
 | ||
| WHERE t1.barcode=12345678;
 | ||
| barcode	f1(t1.barcode)
 | ||
| 12345678	12345106708
 | ||
| 
 | ||
| #
 | ||
| # - Cleanup.
 | ||
| #
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| DROP TABLE t2;
 | ||
| DROP FUNCTION f1;
 | ||
| 
 | ||
| #
 | ||
| # Bug#31226.
 | ||
| #
 | ||
| 
 | ||
| #
 | ||
| # - Prepare.
 | ||
| #
 | ||
| 
 | ||
| 
 | ||
| #
 | ||
| # - Create required objects.
 | ||
| #
 | ||
| 
 | ||
| CREATE TABLE t1(id INT);
 | ||
| 
 | ||
| INSERT INTO t1 VALUES (1), (2), (3);
 | ||
| 
 | ||
| CREATE FUNCTION f1()
 | ||
| RETURNS DATETIME
 | ||
| NOT DETERMINISTIC NO SQL
 | ||
| RETURN NOW();
 | ||
| 
 | ||
| #
 | ||
| # - Check.
 | ||
| #
 | ||
| 
 | ||
| SELECT f1() FROM t1 GROUP BY 1;
 | ||
| f1()
 | ||
| <timestamp>
 | ||
| 
 | ||
| #
 | ||
| # - Cleanup.
 | ||
| #
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| 
 | ||
| CREATE DATABASE db28318_a;
 | ||
| CREATE DATABASE db28318_b;
 | ||
| CREATE PROCEDURE db28318_a.t1() SELECT "db28318_a.t1";
 | ||
| CREATE PROCEDURE db28318_b.t2() CALL t1();
 | ||
| use db28318_a;
 | ||
| CALL db28318_b.t2();
 | ||
| ERROR 42000: PROCEDURE db28318_b.t1 does not exist
 | ||
| DROP PROCEDURE db28318_a.t1;
 | ||
| DROP PROCEDURE db28318_b.t2;
 | ||
| DROP DATABASE db28318_a;
 | ||
| DROP DATABASE db28318_b;
 | ||
| use test;
 | ||
| CREATE TABLE t1(a int);
 | ||
| CREATE PROCEDURE bug29770()
 | ||
| BEGIN
 | ||
| DECLARE CONTINUE HANDLER FOR SQLSTATE '42S22' SET @state:= 'run';
 | ||
| DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET @exception:= 'run';
 | ||
| SELECT x FROM t1;
 | ||
| END|
 | ||
| CALL bug29770();
 | ||
| SELECT @state, @exception;
 | ||
| @state	@exception
 | ||
| run	NULL
 | ||
| DROP TABLE t1;
 | ||
| DROP PROCEDURE bug29770;
 | ||
| use test;
 | ||
| create table t_33618 (`a` int, unique(`a`), `b` varchar(30)) engine=myisam;
 | ||
| insert into t_33618 (`a`,`b`) values (1,'1'),(2,'2');
 | ||
| create procedure proc_33618(num int)
 | ||
| begin
 | ||
| declare count1 int default '0';
 | ||
| declare vb varchar(30);
 | ||
| declare last_row int;
 | ||
| while(num>=1) do
 | ||
| set num=num-1;
 | ||
| begin
 | ||
| declare cur1 cursor for select `a` from t_33618;
 | ||
| declare continue handler for not found set last_row = 1;
 | ||
| set last_row:=0;
 | ||
| open cur1;
 | ||
| rep1:
 | ||
| repeat
 | ||
| begin
 | ||
| declare exit handler for 1062 begin end;
 | ||
| fetch cur1 into vb;
 | ||
| if (last_row = 1) then
 | ||
| leave rep1;
 | ||
| end if;
 | ||
| end;
 | ||
| until last_row=1
 | ||
| end repeat;
 | ||
| close cur1;
 | ||
| end;
 | ||
| end while;
 | ||
| end//
 | ||
| call proc_33618(20);
 | ||
| drop table t_33618;
 | ||
| drop procedure proc_33618;
 | ||
| #
 | ||
| # Bug#30787: Stored function ignores user defined alias.
 | ||
| #
 | ||
| use test;
 | ||
| create table t1(f1 int);
 | ||
| insert into t1 values(1),(2);
 | ||
| create function func30787(p1 int) returns int
 | ||
| begin
 | ||
| return p1;
 | ||
| end |
 | ||
| select (select func30787(f1)) as ttt from t1;
 | ||
| ttt
 | ||
| 1
 | ||
| 2
 | ||
| drop function func30787;
 | ||
| drop table t1;
 | ||
| CREATE TABLE t1 (id INT);
 | ||
| INSERT INTO t1 VALUES (1),(2),(3),(4);
 | ||
| CREATE PROCEDURE test_sp()
 | ||
| SELECT t1.* FROM t1 RIGHT JOIN t1 t2 ON t1.id=t2.id;
 | ||
| CALL test_sp();
 | ||
| id
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| 4
 | ||
| CALL test_sp();
 | ||
| id
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| 4
 | ||
| DROP PROCEDURE test_sp;
 | ||
| DROP TABLE t1;
 | ||
| create table t1(c1 INT);
 | ||
| create function f1(p1 int) returns varchar(32)
 | ||
| return 'aaa';
 | ||
| create view v1 as select f1(c1) as parent_control_name from t1;
 | ||
| create procedure p1()
 | ||
| begin
 | ||
| select parent_control_name as c1 from v1;
 | ||
| end //
 | ||
| call p1();
 | ||
| c1
 | ||
| call p1();
 | ||
| c1
 | ||
| drop procedure p1;
 | ||
| drop function f1;
 | ||
| drop view v1;
 | ||
| drop table t1;
 | ||
| create procedure `p2`(in `a` text charset utf8)
 | ||
| begin
 | ||
| declare `pos` int default 1;
 | ||
| declare `str` text charset utf8;
 | ||
| set `str` := `a`;
 | ||
| select substr(`str`, `pos`+ 1 ) into `str`;
 | ||
| end $
 | ||
| call `p2`('s s s s s s');
 | ||
| drop procedure `p2`;
 | ||
| create procedure p1() begin select * from t1; end$
 | ||
| call p1$
 | ||
| ERROR 42S02: Table 'test.t1' doesn't exist
 | ||
| create table t1 (a integer)$
 | ||
| call p1$
 | ||
| a
 | ||
| alter table t1 add b integer$
 | ||
| call p1$
 | ||
| a	b
 | ||
| drop table t1;
 | ||
| drop procedure p1;
 | ||
| # ------------------------------------------------------------------
 | ||
| # -- End of 5.0 tests
 | ||
| # ------------------------------------------------------------------
 | ||
| 
 | ||
| #
 | ||
| # Bug#20550.
 | ||
| #
 | ||
| 
 | ||
| #
 | ||
| # - Prepare.
 | ||
| #
 | ||
| 
 | ||
| 
 | ||
| #
 | ||
| # - Create required objects.
 | ||
| #
 | ||
| 
 | ||
| CREATE FUNCTION f1() RETURNS VARCHAR(65525) CHARACTER SET latin1 RETURN 'Hello';
 | ||
| 
 | ||
| CREATE FUNCTION f2() RETURNS TINYINT RETURN 1;
 | ||
| 
 | ||
| CREATE VIEW v1 AS SELECT f1();
 | ||
| 
 | ||
| CREATE VIEW v2 AS SELECT f2();
 | ||
| 
 | ||
| #
 | ||
| # - Check.
 | ||
| #
 | ||
| 
 | ||
| SELECT DATA_TYPE FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'v1';
 | ||
| DATA_TYPE
 | ||
| varchar
 | ||
| 
 | ||
| SELECT DATA_TYPE FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'v2';
 | ||
| DATA_TYPE
 | ||
| tinyint
 | ||
| 
 | ||
| #
 | ||
| # - Cleanup.
 | ||
| #
 | ||
| 
 | ||
| DROP FUNCTION f1;
 | ||
| DROP FUNCTION f2;
 | ||
| DROP VIEW v1;
 | ||
| DROP VIEW v2;
 | ||
| 
 | ||
| #
 | ||
| # - Bug#24923: prepare.
 | ||
| #
 | ||
| 
 | ||
| 
 | ||
| #
 | ||
| # - Bug#24923: create required objects.
 | ||
| #
 | ||
| 
 | ||
| CREATE FUNCTION f1(p INT)
 | ||
| RETURNS ENUM ('Very_long_enum_element_identifier',
 | ||
| 'Another_very_long_enum_element_identifier')
 | ||
| BEGIN
 | ||
| CASE p
 | ||
| WHEN 1 THEN
 | ||
| RETURN 'Very_long_enum_element_identifier';
 | ||
| ELSE
 | ||
| RETURN 'Another_very_long_enum_element_identifier';
 | ||
| END CASE;
 | ||
| END|
 | ||
| 
 | ||
| #
 | ||
| # - Bug#24923: check.
 | ||
| #
 | ||
| 
 | ||
| SELECT f1(1);
 | ||
| f1(1)
 | ||
| Very_long_enum_element_identifier
 | ||
| 
 | ||
| SELECT f1(2);
 | ||
| f1(2)
 | ||
| Another_very_long_enum_element_identifier
 | ||
| 
 | ||
| SHOW CREATE FUNCTION f1;
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| f1		CREATE DEFINER=`root`@`localhost` FUNCTION `f1`(p INT) RETURNS enum('Very_long_enum_element_identifier','Another_very_long_enum_element_identifier') CHARSET utf8mb4 COLLATE utf8mb4_uca1400_ai_ci
 | ||
| BEGIN
 | ||
| CASE p
 | ||
| WHEN 1 THEN
 | ||
| RETURN 'Very_long_enum_element_identifier';
 | ||
| ELSE
 | ||
| RETURN 'Another_very_long_enum_element_identifier';
 | ||
| END CASE;
 | ||
| END	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| #
 | ||
| # - Bug#24923: cleanup.
 | ||
| #
 | ||
| 
 | ||
| DROP FUNCTION f1;
 | ||
| 
 | ||
| set @old_mode= @@sql_mode;
 | ||
| set @@sql_mode= cast(pow(2,32)-1 as unsigned integer);
 | ||
| select @@sql_mode into @full_mode;
 | ||
| create procedure p() as begin end;
 | ||
| call p();
 | ||
| set @@sql_mode= @old_mode;
 | ||
| select replace(@full_mode, 'ALLOW_INVALID_DATES', 'INVALID_DATES') into @full_mode;
 | ||
| select name from mysql.proc where name = 'p' and sql_mode = @full_mode;
 | ||
| name
 | ||
| p
 | ||
| drop procedure p;
 | ||
| CREATE DEFINER = 'root'@'localhost' PROCEDURE p1()
 | ||
| NOT DETERMINISTIC
 | ||
| CONTAINS SQL
 | ||
| SQL SECURITY DEFINER
 | ||
| COMMENT ''
 | ||
| BEGIN
 | ||
| SHOW TABLE STATUS like 't1';
 | ||
| END;//
 | ||
| CREATE TABLE t1 (f1 INT);
 | ||
| CALL p1();
 | ||
| CALL p1();
 | ||
| CALL p1();
 | ||
| CALL p1();
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP TABLE t1;
 | ||
| CREATE TABLE t1 ( f1 integer, primary key (f1));
 | ||
| CREATE TABLE t2 LIKE t1;
 | ||
| CREATE TEMPORARY TABLE t3 LIKE t1;
 | ||
| CREATE PROCEDURE p1 () BEGIN SELECT f1 FROM t3 AS A WHERE A.f1 IN ( SELECT f1 FROM t3 ) ;
 | ||
| END|
 | ||
| CALL p1;
 | ||
| f1
 | ||
| CREATE VIEW t3 AS SELECT f1 FROM t2 A WHERE A.f1 IN ( SELECT f1 FROM t2 );
 | ||
| DROP TABLE t3;
 | ||
| CALL p1;
 | ||
| f1
 | ||
| CALL p1;
 | ||
| f1
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP TABLE t1, t2;
 | ||
| DROP VIEW t3;
 | ||
| #
 | ||
| # Bug #46629: Item_in_subselect::val_int(): Assertion `0' 
 | ||
| # on subquery inside a SP
 | ||
| #
 | ||
| CREATE TABLE t1(a INT);
 | ||
| CREATE TABLE t2(a INT, b INT PRIMARY KEY);
 | ||
| CREATE PROCEDURE p1 () 
 | ||
| BEGIN 
 | ||
| SELECT a FROM t1 A WHERE A.b IN (SELECT b FROM t2 AS B);
 | ||
| END|
 | ||
| CALL p1;
 | ||
| ERROR 42S22: Unknown column 'A.b' in 'IN/ALL/ANY'
 | ||
| CALL p1;
 | ||
| ERROR 42S22: Unknown column 'A.b' in 'IN/ALL/ANY'
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP TABLE t1, t2;
 | ||
| #
 | ||
| # Bug#47627: SET @@{global.session}.local_variable in stored routine causes crash
 | ||
| # Bug#48626: Crash or lost connection using SET for declared variables with @@
 | ||
| #
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE v INT DEFAULT 0;
 | ||
| SET @@SESSION.v= 10;
 | ||
| END//
 | ||
| ERROR HY000: Unknown system variable 'v'
 | ||
| CREATE PROCEDURE p2()
 | ||
| BEGIN
 | ||
| DECLARE v INT DEFAULT 0;
 | ||
| SET v= 10;
 | ||
| END//
 | ||
| call p2()//
 | ||
| CREATE PROCEDURE p3()
 | ||
| BEGIN
 | ||
| DECLARE v INT DEFAULT 0;
 | ||
| SELECT @@SESSION.v;
 | ||
| END//
 | ||
| ERROR HY000: Unknown system variable 'v'
 | ||
| CREATE PROCEDURE p4()
 | ||
| BEGIN
 | ||
| DECLARE v INT DEFAULT 0;
 | ||
| SET @@GLOBAL.v= 10;
 | ||
| END//
 | ||
| ERROR HY000: Unknown system variable 'v'
 | ||
| CREATE PROCEDURE p5()
 | ||
| BEGIN
 | ||
| DECLARE init_connect INT DEFAULT 0;
 | ||
| SET init_connect= 10;
 | ||
| SET @@GLOBAL.init_connect= 'SELECT 1';
 | ||
| SET @@SESSION.IDENTITY= 1;
 | ||
| SELECT @@SESSION.IDENTITY;
 | ||
| SELECT @@GLOBAL.init_connect;
 | ||
| SELECT init_connect;
 | ||
| END//
 | ||
| CREATE PROCEDURE p6()
 | ||
| BEGIN
 | ||
| DECLARE v INT DEFAULT 0;
 | ||
| SET @@v= 0;
 | ||
| END//
 | ||
| ERROR HY000: Unknown system variable 'v'
 | ||
| SET @old_init_connect= @@GLOBAL.init_connect;
 | ||
| CALL p5();
 | ||
| @@SESSION.IDENTITY
 | ||
| 1
 | ||
| @@GLOBAL.init_connect
 | ||
| SELECT 1
 | ||
| init_connect
 | ||
| 10
 | ||
| SET @@GLOBAL.init_connect= @old_init_connect;
 | ||
| DROP PROCEDURE p2;
 | ||
| DROP PROCEDURE p5;
 | ||
| #
 | ||
| # Bug#11840395 (formerly known as bug#60347):
 | ||
| # The string "versiondata" seems
 | ||
| # to be 'leaking' into the schema name space
 | ||
| #
 | ||
| CREATE DATABASE mixedCaseDbName;
 | ||
| CREATE PROCEDURE mixedCaseDbName.tryMyProc() begin end|
 | ||
| CREATE FUNCTION mixedCaseDbName.tryMyFunc() returns text begin return 'IT WORKS'; end
 | ||
| |
 | ||
| call mixedCaseDbName.tryMyProc();
 | ||
| select mixedCaseDbName.tryMyFunc();
 | ||
| mixedCaseDbName.tryMyFunc()
 | ||
| IT WORKS
 | ||
| DROP DATABASE mixedCaseDbName;
 | ||
| #
 | ||
| # Bug#11766594  59736: SELECT DISTINCT.. INCORRECT RESULT WITH DETERMINISTIC FUNCTION IN WHERE C
 | ||
| #
 | ||
| CREATE TABLE t1 (a INT, b INT, KEY(b));
 | ||
| CREATE TABLE t2 (c INT, d INT, KEY(c));
 | ||
| INSERT INTO t1 VALUES (1,1),(1,1),(1,2);
 | ||
| INSERT INTO t2 VALUES (1,1),(1,2);
 | ||
| CREATE FUNCTION f1() RETURNS INT DETERMINISTIC
 | ||
| BEGIN
 | ||
| DECLARE a int;
 | ||
| -- SQL statement inside
 | ||
| SELECT 1 INTO a;
 | ||
| RETURN a;
 | ||
| END $
 | ||
| SELECT COUNT(DISTINCT d) FROM t1, t2  WHERE a = c AND b = f1();
 | ||
| COUNT(DISTINCT d)
 | ||
| 2
 | ||
| DROP FUNCTION f1;
 | ||
| DROP TABLE t1, t2;
 | ||
| # ------------------------------------------------------------------
 | ||
| # -- End of 5.1 tests
 | ||
| # ------------------------------------------------------------------
 | ||
| CREATE FUNCTION f1() RETURNS INT
 | ||
| BEGIN
 | ||
| DECLARE v INT;
 | ||
| SELECT a INTO v FROM t_non_existing;
 | ||
| RETURN 1;
 | ||
| END|
 | ||
| CREATE TABLE t1 (a INT) ENGINE = myisam;
 | ||
| INSERT INTO t1 VALUES (1);
 | ||
| SELECT * FROM t1 WHERE a = f1();
 | ||
| ERROR 42S02: Table 'test.t_non_existing' doesn't exist
 | ||
| DROP FUNCTION f1;
 | ||
| DROP TABLE t1;
 | ||
| CREATE PROCEDURE p1(a INT, b CHAR)
 | ||
| BEGIN
 | ||
| IF a > 0 THEN
 | ||
| CALL p1(a-1, 'ab');
 | ||
| ELSE
 | ||
| SELECT 1;
 | ||
| END IF;
 | ||
| END|
 | ||
| SET @save_max_sp_recursion= @@max_sp_recursion_depth;
 | ||
| SET @@max_sp_recursion_depth= 5;
 | ||
| CALL p1(4, 'a');
 | ||
| 1
 | ||
| 1
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'b' at row 0
 | ||
| Warning	1265	Data truncated for column 'b' at row 0
 | ||
| Warning	1265	Data truncated for column 'b' at row 0
 | ||
| Warning	1265	Data truncated for column 'b' at row 0
 | ||
| SET @@max_sp_recursion_depth= @save_max_sp_recursion;
 | ||
| DROP PROCEDURE p1;
 | ||
| CREATE PROCEDURE p1(a CHAR)
 | ||
| BEGIN
 | ||
| SELECT 1;
 | ||
| SELECT CAST('10 ' as UNSIGNED INTEGER);
 | ||
| SELECT 1;
 | ||
| END|
 | ||
| CALL p1('data truncated parameter');
 | ||
| 1
 | ||
| 1
 | ||
| CAST('10 ' as UNSIGNED INTEGER)
 | ||
| 10
 | ||
| 1
 | ||
| 1
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'a' at row 0
 | ||
| Note	1292	Truncated incorrect INTEGER value: '10 '
 | ||
| DROP PROCEDURE p1;
 | ||
| CREATE PROCEDURE p1()
 | ||
| CALL p2()|
 | ||
| CREATE PROCEDURE p2()
 | ||
| CALL p3()|
 | ||
| CREATE PROCEDURE p3()
 | ||
| CALL p4()|
 | ||
| CREATE PROCEDURE p4()
 | ||
| BEGIN
 | ||
| SELECT 1;
 | ||
| SELECT CAST('10 ' as UNSIGNED INTEGER);
 | ||
| SELECT 2;
 | ||
| END|
 | ||
| CALL p1();
 | ||
| 1
 | ||
| 1
 | ||
| CAST('10 ' as UNSIGNED INTEGER)
 | ||
| 10
 | ||
| 2
 | ||
| 2
 | ||
| Warnings:
 | ||
| Note	1292	Truncated incorrect INTEGER value: '10 '
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP PROCEDURE p2;
 | ||
| DROP PROCEDURE p3;
 | ||
| DROP PROCEDURE p4;
 | ||
| CREATE TABLE t1 (a CHAR(2));
 | ||
| INSERT INTO t1 VALUES ('aa');
 | ||
| CREATE FUNCTION f1() RETURNS CHAR
 | ||
| RETURN (SELECT f2())|
 | ||
| CREATE FUNCTION f2() RETURNS CHAR
 | ||
| RETURN (SELECT f3())|
 | ||
| CREATE FUNCTION f3() RETURNS CHAR
 | ||
| RETURN (SELECT f4())|
 | ||
| CREATE FUNCTION f4() RETURNS CHAR
 | ||
| BEGIN
 | ||
| RETURN (SELECT a FROM t1);
 | ||
| END|
 | ||
| SELECT f1();
 | ||
| f1()
 | ||
| a
 | ||
| Warnings:
 | ||
| Warning	1265	Data truncated for column 'f4()' at row 0
 | ||
| DROP FUNCTION f1;
 | ||
| DROP FUNCTION f2;
 | ||
| DROP FUNCTION f3;
 | ||
| DROP FUNCTION f4;
 | ||
| DROP TABLE t1;
 | ||
| #
 | ||
| # Bug#34197: CREATE PROCEDURE fails when COMMENT truncated in non 
 | ||
| #            strict SQL mode
 | ||
| #
 | ||
| CREATE PROCEDURE p1 ()
 | ||
| COMMENT
 | ||
| '12345678901234567890123456789012345678901234567890123456789012345678901234567890'
 | ||
| BEGIN
 | ||
| END;
 | ||
| SELECT comment FROM mysql.proc WHERE name = "p1";
 | ||
| comment
 | ||
| 12345678901234567890123456789012345678901234567890123456789012345678901234567890
 | ||
| SELECT routine_comment FROM information_schema.routines WHERE routine_name = "p1";
 | ||
| routine_comment
 | ||
| 12345678901234567890123456789012345678901234567890123456789012345678901234567890
 | ||
| DROP PROCEDURE p1;
 | ||
| #
 | ||
| # Bug #47313 assert in check_key_in_view during CALL procedure
 | ||
| #
 | ||
| CREATE PROCEDURE p1(IN x INT) INSERT INTO t1 VALUES (x);
 | ||
| CREATE VIEW t1 AS SELECT 10 AS f1;
 | ||
| # t1 refers to the view
 | ||
| CALL p1(1);
 | ||
| ERROR HY000: The target table t1 of the INSERT is not insertable-into
 | ||
| CREATE TEMPORARY TABLE t1 (f1 INT);
 | ||
| CALL p1(2);
 | ||
| DROP VIEW t1;
 | ||
| # t1 now refers to the temporary table
 | ||
| CALL p1(3);
 | ||
| # Check which values were inserted into the temp table.
 | ||
| SELECT * FROM t1;
 | ||
| f1
 | ||
| 2
 | ||
| 3
 | ||
| DROP TEMPORARY TABLE t1;
 | ||
| DROP PROCEDURE p1;
 | ||
| # Now test what happens if the sp cache is invalidated.
 | ||
| CREATE PROCEDURE p1(IN x INT) INSERT INTO t1 VALUES (x);
 | ||
| CREATE VIEW t1 AS SELECT 10 AS f1;
 | ||
| CREATE VIEW v2_unrelated AS SELECT 1 AS r1;
 | ||
| # Load the procedure into the sp cache
 | ||
| CALL p1(4);
 | ||
| ERROR HY000: The target table t1 of the INSERT is not insertable-into
 | ||
| CREATE TEMPORARY TABLE t1 (f1 int);
 | ||
| ALTER VIEW v2_unrelated AS SELECT 2 AS r1;
 | ||
| # Alter view causes the sp cache to be invalidated.
 | ||
| # Now t1 refers to the temporary table, not the view.
 | ||
| CALL p1(5);
 | ||
| # Check which values were inserted into the temp table.
 | ||
| SELECT * FROM t1;
 | ||
| f1
 | ||
| 5
 | ||
| DROP TEMPORARY TABLE t1;
 | ||
| DROP VIEW t1, v2_unrelated;
 | ||
| DROP PROCEDURE p1;
 | ||
| CREATE PROCEDURE p1(IN x INT) INSERT INTO t1 VALUES (x);
 | ||
| CREATE TEMPORARY TABLE t1 (f1 INT);
 | ||
| # t1 refers to the temporary table
 | ||
| CALL p1(6);
 | ||
| CREATE VIEW t1 AS SELECT 10 AS f1;
 | ||
| # Create view causes the sp cache to be invalidated.
 | ||
| # t1 still refers to the temporary table since it shadows the view.
 | ||
| CALL p1(7);
 | ||
| DROP VIEW t1;
 | ||
| # Check which values were inserted into the temp table.
 | ||
| SELECT * FROM t1;
 | ||
| f1
 | ||
| 6
 | ||
| 7
 | ||
| DROP TEMPORARY TABLE t1;
 | ||
| DROP PROCEDURE p1;
 | ||
| #
 | ||
| # Bug #11918 Can't use a declared variable in LIMIT clause
 | ||
| #
 | ||
| create table t1 (c1 int);
 | ||
| insert into t1 (c1) values (1), (2), (3), (4), (5);
 | ||
| create procedure p1()
 | ||
| begin
 | ||
| declare a integer;
 | ||
| declare b integer;
 | ||
| select * from t1 limit a, b;
 | ||
| end|
 | ||
| # How do we handle NULL limit values?
 | ||
| call p1();
 | ||
| c1
 | ||
| drop table t1;
 | ||
| create table t1 (a int);
 | ||
| insert into t1 (a) values (1), (2), (3), (4), (5);
 | ||
| #
 | ||
| # Do we correctly resolve identifiers in LIMIT?
 | ||
| # DROP and CREATE results in SP statement recompilation
 | ||
| # so second execution of the procedure p1() doesn't lead
 | ||
| # to issuing an error
 | ||
| #
 | ||
| call p1();
 | ||
| a
 | ||
| # 
 | ||
| # Drop and recreate the procedure, then repeat
 | ||
| #
 | ||
| drop procedure p1;
 | ||
| create procedure p1()
 | ||
| begin
 | ||
| declare a integer;
 | ||
| declare b integer;
 | ||
| select * from t1 limit a, b;
 | ||
| end|
 | ||
| # Stored procedure variables are resolved correctly in the LIMIT
 | ||
| call p1();
 | ||
| a
 | ||
| drop table t1;
 | ||
| create table t1 (c1 int);
 | ||
| insert into t1 (c1) values (1), (2), (3), (4), (5);
 | ||
| drop procedure p1;
 | ||
| # Try to create a procedure that
 | ||
| # refers to non-existing variables.
 | ||
| create procedure p1(p1 integer, p2 integer)
 | ||
| select * from t1 limit a, b;
 | ||
| ERROR 42000: Undeclared variable: a
 | ||
| #
 | ||
| # Try to use data types not allowed in LIMIT 
 | ||
| #
 | ||
| create procedure p1(p1 date, p2 date) select * from t1 limit p1, p2;
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create procedure p1(p1 integer, p2 float) select * from t1 limit p1, p2;
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create procedure p1(p1 integer, p2 char(1)) select * from t1 limit p1, p2;
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create procedure p1(p1 varchar(5), p2 char(1)) select * from t1 limit p1, p2;
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create procedure p1(p1 decimal, p2 decimal) select * from t1 limit p1, p2;
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create procedure p1(p1 double, p2 double) select * from t1 limit p1, p2;
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| #
 | ||
| # Finally, test the valid case.
 | ||
| #
 | ||
| create procedure p1(p1 integer, p2 integer)
 | ||
| select * from t1 limit p1, p2;
 | ||
| call p1(NULL, NULL);
 | ||
| c1
 | ||
| call p1(0, 0);
 | ||
| c1
 | ||
| call p1(0, -1);
 | ||
| c1
 | ||
| 1
 | ||
| 2
 | ||
| 3
 | ||
| 4
 | ||
| 5
 | ||
| call p1(-1, 0);
 | ||
| c1
 | ||
| call p1(-1, -1);
 | ||
| c1
 | ||
| call p1(0, 1);
 | ||
| c1
 | ||
| 1
 | ||
| call p1(1, 0);
 | ||
| c1
 | ||
| call p1(1, 5);
 | ||
| c1
 | ||
| 2
 | ||
| 3
 | ||
| 4
 | ||
| 5
 | ||
| call p1(3, 2);
 | ||
| c1
 | ||
| 4
 | ||
| 5
 | ||
| # Try to create a function that
 | ||
| # refers to non-existing variables.
 | ||
| create function f1(p1 integer, p2 integer)
 | ||
| returns int
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = (select count(*) from t1 limit a, b);
 | ||
| return a;
 | ||
| end|
 | ||
| ERROR 42000: Undeclared variable: b
 | ||
| create function f1()
 | ||
| returns int
 | ||
| begin
 | ||
| declare a, b, c int;
 | ||
| set a = (select count(*) from t1 limit b, c);
 | ||
| return a;
 | ||
| end|
 | ||
| # How do we handle NULL limit values?
 | ||
| select f1();
 | ||
| f1()
 | ||
| NULL
 | ||
| drop function f1;
 | ||
| #
 | ||
| # Try to use data types not allowed in LIMIT 
 | ||
| #
 | ||
| create function f1(p1 date, p2 date)
 | ||
| returns int
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = (select count(*) from t1 limit p1, p2);
 | ||
| return a;
 | ||
| end|
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create function f1(p1 integer, p2 float)
 | ||
| returns int
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = (select count(*) from t1 limit p1, p2);
 | ||
| return a;
 | ||
| end|
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create function f1(p1 integer, p2 char(1))
 | ||
| returns int
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = (select count(*) from t1 limit p1, p2);
 | ||
| return a;
 | ||
| end|
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create function f1(p1 varchar(5), p2 char(1))
 | ||
| returns int
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = (select count(*) from t1 limit p1, p2);
 | ||
| return a;
 | ||
| end|
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create function f1(p1 decimal, p2 decimal)
 | ||
| returns int
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = (select count(*) from t1 limit p1, p2);
 | ||
| return a;
 | ||
| end|
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| create function f1(p1 double, p2 double)
 | ||
| returns int
 | ||
| begin
 | ||
| declare a int;
 | ||
| set a = (select count(*) from t1 limit p1, p2);
 | ||
| return a;
 | ||
| end|
 | ||
| ERROR HY000: A variable of a non-integer based type in LIMIT clause
 | ||
| #
 | ||
| # Finally, test the valid case.
 | ||
| #
 | ||
| create function f1(p1 integer, p2 integer)
 | ||
| returns int
 | ||
| begin
 | ||
| declare count int;
 | ||
| set count= (select count(*) from (select * from t1 limit p1, p2) t_1);
 | ||
| return count;
 | ||
| end|
 | ||
| select f1(0, 0);
 | ||
| f1(0, 0)
 | ||
| 0
 | ||
| select f1(0, -1);
 | ||
| f1(0, -1)
 | ||
| 5
 | ||
| select f1(-1, 0);
 | ||
| f1(-1, 0)
 | ||
| 0
 | ||
| select f1(-1, -1);
 | ||
| f1(-1, -1)
 | ||
| 0
 | ||
| select f1(0, 1);
 | ||
| f1(0, 1)
 | ||
| 1
 | ||
| select f1(1, 0);
 | ||
| f1(1, 0)
 | ||
| 0
 | ||
| select f1(1, 5);
 | ||
| f1(1, 5)
 | ||
| 4
 | ||
| select f1(3, 2);
 | ||
| f1(3, 2)
 | ||
| 2
 | ||
| # Cleanup
 | ||
| drop table t1;
 | ||
| drop procedure p1;
 | ||
| drop function f1;
 | ||
| # 
 | ||
| # BUG#11766234: 59299: ASSERT (TABLE_REF->TABLE || TABLE_REF->VIEW) 
 | ||
| #               FAILS IN SET_FIELD_ITERATOR
 | ||
| # 
 | ||
| CREATE TABLE t1 (a INT);
 | ||
| CREATE TABLE t2 (a INT);
 | ||
| CREATE VIEW v1 AS SELECT a FROM t2;
 | ||
| CREATE PROCEDURE proc() SELECT * FROM t1 NATURAL JOIN v1;
 | ||
| ALTER TABLE t2 CHANGE COLUMN a b CHAR;
 | ||
| 
 | ||
| CALL proc();
 | ||
| ERROR HY000: View 'test.v1' references invalid table(s) or column(s) or function(s) or definer/invoker of view lack rights to use them
 | ||
| CALL proc();
 | ||
| ERROR HY000: View 'test.v1' references invalid table(s) or column(s) or function(s) or definer/invoker of view lack rights to use them
 | ||
| 
 | ||
| DROP TABLE t1,t2;
 | ||
| DROP VIEW v1;
 | ||
| DROP PROCEDURE proc;
 | ||
| 
 | ||
| # --
 | ||
| # -- Bug 11765684 - 58674: SP-cache does not detect changes in
 | ||
| # -- pre-locking list caused by triggers
 | ||
| # --- 
 | ||
| CREATE TABLE t1(a INT);
 | ||
| CREATE TABLE t2(a INT);
 | ||
| CREATE TABLE t3(a INT);
 | ||
| CREATE PROCEDURE p1()
 | ||
| INSERT INTO t1(a) VALUES (1);
 | ||
| 
 | ||
| CREATE TRIGGER t1_ai AFTER INSERT ON t1
 | ||
| FOR EACH ROW
 | ||
| INSERT INTO t2(a) VALUES (new.a);
 | ||
| 
 | ||
| CALL p1();
 | ||
| 
 | ||
| CREATE TRIGGER t1_bi BEFORE INSERT ON t1
 | ||
| FOR EACH ROW
 | ||
| INSERT INTO t3(a) VALUES (new.a);
 | ||
| 
 | ||
| CALL p1();
 | ||
| 
 | ||
| DROP TABLE t1, t2, t3;
 | ||
| DROP PROCEDURE p1;
 | ||
| 
 | ||
| 
 | ||
| # --
 | ||
| # -- Bug#12652769 - 61470: case operator in stored routine retains old
 | ||
| # -- value of input parameter
 | ||
| # --- 
 | ||
| CREATE TABLE t1 (s1 CHAR(5) CHARACTER SET utf8);
 | ||
| INSERT INTO t1 VALUES ('a');
 | ||
| CREATE PROCEDURE p1(dt DATETIME, i INT)
 | ||
| BEGIN
 | ||
| SELECT
 | ||
| CASE
 | ||
| WHEN i = 1 THEN 2
 | ||
| ELSE dt
 | ||
| END AS x1;
 | ||
| SELECT
 | ||
| CASE _latin1'a'
 | ||
|       WHEN _utf8'a' THEN 'A'
 | ||
|     END AS x2;
 | ||
| SELECT
 | ||
| CASE _utf8'a'
 | ||
|       WHEN _latin1'a' THEN _utf8'A'
 | ||
|     END AS x3;
 | ||
| SELECT
 | ||
| CASE s1
 | ||
| WHEN _latin1'a' THEN _latin1'b'
 | ||
|       ELSE _latin1'c'
 | ||
|     END AS x4
 | ||
| FROM t1;
 | ||
| END|
 | ||
| 
 | ||
| CALL p1('2011-04-03 05:14:10', 1);
 | ||
| x1
 | ||
| 2
 | ||
| x2
 | ||
| A
 | ||
| x3
 | ||
| A
 | ||
| x4
 | ||
| b
 | ||
| CALL p1('2011-04-03 05:14:11', 2);
 | ||
| x1
 | ||
| 2011-04-03 05:14:11
 | ||
| x2
 | ||
| A
 | ||
| x3
 | ||
| A
 | ||
| x4
 | ||
| b
 | ||
| CALL p1('2011-04-03 05:14:12', 2);
 | ||
| x1
 | ||
| 2011-04-03 05:14:12
 | ||
| x2
 | ||
| A
 | ||
| x3
 | ||
| A
 | ||
| x4
 | ||
| b
 | ||
| CALL p1('2011-04-03 05:14:13', 2);
 | ||
| x1
 | ||
| 2011-04-03 05:14:13
 | ||
| x2
 | ||
| A
 | ||
| x3
 | ||
| A
 | ||
| x4
 | ||
| b
 | ||
| 
 | ||
| DROP TABLE t1;
 | ||
| DROP PROCEDURE p1;
 | ||
| 
 | ||
| #
 | ||
| # Bug#12621017 - Crash if a sp variable is used in the
 | ||
| #                limit clause of a set statement
 | ||
| #
 | ||
| CREATE TABLE t1 (c1 INT);
 | ||
| INSERT INTO t1 VALUES (1);
 | ||
| CREATE PROCEDURE p1() 
 | ||
| BEGIN 
 | ||
| DECLARE foo, cnt INT UNSIGNED DEFAULT 1; 
 | ||
| SET foo = (SELECT MIN(c1) FROM t1 LIMIT cnt); 
 | ||
| END|
 | ||
| CREATE PROCEDURE p2()
 | ||
| BEGIN
 | ||
| DECLARE iLimit INT;
 | ||
| DECLARE iVal INT;
 | ||
| DECLARE cur1 CURSOR FOR
 | ||
| SELECT c1 FROM t1
 | ||
| LIMIT iLimit;
 | ||
| SET iLimit=1;
 | ||
| OPEN cur1;
 | ||
| FETCH cur1 INTO iVal;
 | ||
| END|
 | ||
| CALL p1();
 | ||
| CALL p2();
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP PROCEDURE p2;
 | ||
| DROP TABLE t1;
 | ||
| 
 | ||
| # Bug#13805127: Stored program cache produces wrong result in same THD
 | ||
| 
 | ||
| CREATE PROCEDURE p1(x INT UNSIGNED)
 | ||
| BEGIN
 | ||
| SELECT c1, t2.c2, count(c3)
 | ||
| FROM
 | ||
| (
 | ||
| SELECT 3 as c2 FROM dual WHERE x = 1
 | ||
| UNION
 | ||
| SELECT 2       FROM dual WHERE x = 1 OR x = 2
 | ||
| ) AS t1,
 | ||
| (
 | ||
| SELECT '2012-03-01 01:00:00' AS c1, 3 as c2, 1 as c3 FROM dual
 | ||
| UNION
 | ||
| SELECT '2012-03-01 02:00:00',       3,       2       FROM dual
 | ||
| UNION
 | ||
| SELECT '2012-03-01 01:00:00',       2,       1       FROM dual
 | ||
| ) AS t2
 | ||
| WHERE t2.c2 = t1.c2
 | ||
| GROUP BY c1, c2
 | ||
| ;
 | ||
| END|
 | ||
| 
 | ||
| CALL p1(1);
 | ||
| c1	c2	count(c3)
 | ||
| 2012-03-01 01:00:00	2	1
 | ||
| 2012-03-01 01:00:00	3	1
 | ||
| 2012-03-01 02:00:00	3	1
 | ||
| CALL p1(2);
 | ||
| c1	c2	count(c3)
 | ||
| 2012-03-01 01:00:00	2	1
 | ||
| CALL p1(1);
 | ||
| c1	c2	count(c3)
 | ||
| 2012-03-01 01:00:00	2	1
 | ||
| 2012-03-01 01:00:00	3	1
 | ||
| 2012-03-01 02:00:00	3	1
 | ||
| DROP PROCEDURE p1;
 | ||
| # End of 5.5 test
 | ||
| FLUSH USER_STATISTICS;
 | ||
| CREATE PROCEDURE sp() ALTER TABLE non_existing_table OPTIMIZE PARTITION p0;
 | ||
| CALL sp;
 | ||
| Table	Op	Msg_type	Msg_text
 | ||
| test.non_existing_table	optimize	Error	Table 'test.non_existing_table' doesn't exist
 | ||
| test.non_existing_table	optimize	status	Operation failed
 | ||
| SELECT 1;
 | ||
| 1
 | ||
| 1
 | ||
| DROP PROCEDURE sp;
 | ||
| CREATE PROCEDURE sp() SET STATEMENT SQL_SELECT_LIMIT=0 FOR SHOW USER_STATISTICS;
 | ||
| CALL sp;
 | ||
| User	Total_connections	Concurrent_connections	Connected_time	Busy_time	Cpu_time	Bytes_received	Bytes_sent	Binlog_bytes_written	Rows_read	Rows_sent	Rows_deleted	Rows_inserted	Rows_updated	Key_read_hits	Key_read_misses	Select_commands	Update_commands	Other_commands	Commit_transactions	Rollback_transactions	Denied_connections	Lost_connections	Access_denied	Empty_queries	Total_ssl_connections	Max_statement_time_exceeded
 | ||
| SELECT 1;
 | ||
| 1
 | ||
| 1
 | ||
| DROP PROCEDURE sp;
 | ||
| #
 | ||
| # Bug#12663165 SP DEAD CODE REMOVAL DOESN'T UNDERSTAND CONTINUE HANDLERS
 | ||
| #
 | ||
| CREATE FUNCTION f1() RETURNS INT
 | ||
| BEGIN
 | ||
| DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN END;
 | ||
| BEGIN
 | ||
| DECLARE CONTINUE HANDLER FOR SQLEXCEPTION RETURN f1();
 | ||
| BEGIN
 | ||
| DECLARE CONTINUE HANDLER FOR SQLEXCEPTION RETURN f1();
 | ||
| RETURN f1();
 | ||
| END;
 | ||
| END;
 | ||
| RETURN 1;
 | ||
| END $
 | ||
| SELECT f1();
 | ||
| f1()
 | ||
| 1
 | ||
| DROP FUNCTION f1;
 | ||
| # ------------------------------------------------------------------
 | ||
| # -- End of 5.1 tests
 | ||
| # ------------------------------------------------------------------
 | ||
| #
 | ||
| # lp:993459 Execution of PS for a query with GROUP BY
 | ||
| # returns wrong result (see also mysql bug#13805127)
 | ||
| #
 | ||
| 
 | ||
| # Bug#13805127: Stored program cache produces wrong result in same THD
 | ||
| 
 | ||
| CREATE PROCEDURE p1(x INT UNSIGNED)
 | ||
| BEGIN
 | ||
| SELECT c1, t2.c2, count(c3)
 | ||
| FROM
 | ||
| (
 | ||
| SELECT 3 as c2 FROM dual WHERE x = 1
 | ||
| UNION
 | ||
| SELECT 2       FROM dual WHERE x = 1 OR x = 2
 | ||
| ) AS t1,
 | ||
| (
 | ||
| SELECT '2012-03-01 01:00:00' AS c1, 3 as c2, 1 as c3 FROM dual
 | ||
| UNION
 | ||
| SELECT '2012-03-01 02:00:00',       3,       2       FROM dual
 | ||
| UNION
 | ||
| SELECT '2012-03-01 01:00:00',       2,       1       FROM dual
 | ||
| ) AS t2
 | ||
| WHERE t2.c2 = t1.c2
 | ||
| GROUP BY c1, c2
 | ||
| ;
 | ||
| END|
 | ||
| 
 | ||
| CALL p1(1);
 | ||
| c1	c2	count(c3)
 | ||
| 2012-03-01 01:00:00	2	1
 | ||
| 2012-03-01 01:00:00	3	1
 | ||
| 2012-03-01 02:00:00	3	1
 | ||
| CALL p1(2);
 | ||
| c1	c2	count(c3)
 | ||
| 2012-03-01 01:00:00	2	1
 | ||
| CALL p1(1);
 | ||
| c1	c2	count(c3)
 | ||
| 2012-03-01 01:00:00	2	1
 | ||
| 2012-03-01 01:00:00	3	1
 | ||
| 2012-03-01 02:00:00	3	1
 | ||
| DROP PROCEDURE p1;
 | ||
| 
 | ||
| MDEV-3900 Optimizer difference between MySQL and MariaDB with stored functions in WHERE clause of UPDATE or DELETE statements
 | ||
| 
 | ||
| CREATE FUNCTION tdn() RETURNS int(7) DETERMINISTIC RETURN to_days(now());
 | ||
| CREATE TABLE t1 (pk INT NOT NULL AUTO_INCREMENT PRIMARY KEY, daynum INT, a CHAR(1), INDEX(daynum), INDEX(a)) ENGINE=MyISAM;
 | ||
| INSERT INTO t1 (daynum) VALUES (1),(2),(3),(4),(5),(TO_DAYS(NOW())),(7),(8);
 | ||
| INSERT INTO t1 (daynum) SELECT a1.daynum FROM t1 a1, t1 a2, t1 a3, t1 a4, t1 a5;
 | ||
| FLUSH TABLES;
 | ||
| FLUSH STATUS;
 | ||
| SHOW STATUS LIKE '%Handler_read%';
 | ||
| Variable_name	Value
 | ||
| Handler_read_first	0
 | ||
| Handler_read_key	0
 | ||
| Handler_read_last	0
 | ||
| Handler_read_next	0
 | ||
| Handler_read_prev	0
 | ||
| Handler_read_retry	0
 | ||
| Handler_read_rnd	0
 | ||
| Handler_read_rnd_deleted	0
 | ||
| Handler_read_rnd_next	0
 | ||
| UPDATE t1 SET a = '+' WHERE daynum=tdn();
 | ||
| SHOW STATUS LIKE '%Handler_read%';
 | ||
| Variable_name	Value
 | ||
| Handler_read_first	0
 | ||
| Handler_read_key	9
 | ||
| Handler_read_last	0
 | ||
| Handler_read_next	4097
 | ||
| Handler_read_prev	0
 | ||
| Handler_read_retry	0
 | ||
| Handler_read_rnd	0
 | ||
| Handler_read_rnd_deleted	0
 | ||
| Handler_read_rnd_next	0
 | ||
| drop function tdn;
 | ||
| drop table t1;
 | ||
| #
 | ||
| # lp:1002157 : testing stored function
 | ||
| # bug#62125        result for null incorrectly yields 1292 warning.
 | ||
| #
 | ||
| CREATE FUNCTION f1() RETURNS VARCHAR(1)
 | ||
| BEGIN RETURN 'X'; END;/
 | ||
| CREATE FUNCTION f2() RETURNS CHAR(1)
 | ||
| BEGIN RETURN 'X'; END;/
 | ||
| CREATE FUNCTION f3() RETURNS VARCHAR(1)
 | ||
| BEGIN RETURN NULL; END;/
 | ||
| CREATE FUNCTION f4() RETURNS CHAR(1)
 | ||
| BEGIN RETURN NULL; END;/
 | ||
| SELECT f1() IS NULL;
 | ||
| f1() IS NULL
 | ||
| 0
 | ||
| SELECT f2() IS NULL;
 | ||
| f2() IS NULL
 | ||
| 0
 | ||
| SELECT f3() IS NULL;
 | ||
| f3() IS NULL
 | ||
| 1
 | ||
| SELECT f4() IS NULL;
 | ||
| f4() IS NULL
 | ||
| 1
 | ||
| DROP FUNCTION f1;
 | ||
| DROP FUNCTION f2;
 | ||
| DROP FUNCTION f3;
 | ||
| DROP FUNCTION f4;
 | ||
| 
 | ||
| Stored procedures and a condition handler in a nested procedure call
 | ||
| doesn't suppress the condition from being passed on to the calling
 | ||
| procedure
 | ||
| 
 | ||
| create table t1 (id int);
 | ||
| create procedure p1 () begin
 | ||
| declare i int default 0;
 | ||
| declare continue handler for not found begin
 | ||
| select "You should see this message and the warning that generated this" as "message";
 | ||
| show warnings;
 | ||
| end;
 | ||
| select id into i from t1;
 | ||
| end$$
 | ||
| create procedure p0 () begin
 | ||
| declare continue handler for not found begin
 | ||
| select "You should NOT see this message" as "message";
 | ||
| end;
 | ||
| call p1();
 | ||
| end$$
 | ||
| call p0();
 | ||
| message
 | ||
| You should see this message and the warning that generated this
 | ||
| Level	Code	Message
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| drop procedure p1;
 | ||
| drop procedure p0;
 | ||
| drop table t1;
 | ||
| 
 | ||
| Test if stored procedures propagates errors
 | ||
| 
 | ||
| create table t1 (id int primary key);
 | ||
| create procedure p1 () begin
 | ||
| insert into t1 values(1);
 | ||
| insert into t1 values(2);
 | ||
| insert into t1 values(2);
 | ||
| insert into t1 values(3);
 | ||
| end$$
 | ||
| create procedure p2 () begin
 | ||
| declare x int;
 | ||
| select id into x from t1 where id=5;
 | ||
| end$$
 | ||
| call p1();
 | ||
| ERROR 23000: Duplicate entry '2' for key 'PRIMARY'
 | ||
| show warnings;
 | ||
| Level	Code	Message
 | ||
| Error	1062	Duplicate entry '2' for key 'PRIMARY'
 | ||
| Note	4094	At line 5 in test.p1
 | ||
| select * from t1;
 | ||
| id
 | ||
| 1
 | ||
| 2
 | ||
| call p2();
 | ||
| Warnings:
 | ||
| Warning	1329	No data - zero rows fetched, selected, or processed
 | ||
| drop procedure p1;
 | ||
| drop procedure p2;
 | ||
| drop table t1;
 | ||
| #
 | ||
| # MDEV-4978 - Server cursor is broken with blobs in the select list,
 | ||
| #             ORDER BY does not work
 | ||
| #
 | ||
| CREATE TABLE t1(a INT, b BLOB);
 | ||
| INSERT INTO t1 VALUES(1,REPEAT('a',4835)),(2,'b'),(3,'c'),(4,'d'),(5,REPEAT('e',805)),(6,'f');
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE done INT DEFAULT 0;
 | ||
| DECLARE v1 INT;
 | ||
| DECLARE v2 BLOB;
 | ||
| DECLARE c1 CURSOR FOR SELECT * FROM t1 ORDER BY a;
 | ||
| DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done=1;
 | ||
| OPEN c1;
 | ||
| REPEAT
 | ||
| FETCH c1 INTO v1, v2;
 | ||
| IF NOT done THEN
 | ||
| SELECT v1;
 | ||
| END IF;
 | ||
| UNTIL done END REPEAT;
 | ||
| CLOSE c1;
 | ||
| END|
 | ||
| CALL p1;
 | ||
| v1
 | ||
| 1
 | ||
| v1
 | ||
| 2
 | ||
| v1
 | ||
| 3
 | ||
| v1
 | ||
| 4
 | ||
| v1
 | ||
| 5
 | ||
| v1
 | ||
| 6
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP TABLE t1;
 | ||
| #
 | ||
| # MDEV-10713: signal 11 error on multi-table update - crash in
 | ||
| # handler::increment_statistics or in make_select or assertion
 | ||
| # failure pfs_thread == ((PFS_thread*) pthread_getspecific((THR_PFS)))
 | ||
| #
 | ||
| CREATE TABLE `t1` (
 | ||
| `CLOSE_YN` varchar(10) COLLATE utf8_bin DEFAULT NULL
 | ||
| ) DEFAULT CHARSET=utf8 COLLATE=utf8_bin ;
 | ||
| CREATE TABLE `t2` (
 | ||
| `ap_close_to` varchar(8) COLLATE utf8_bin DEFAULT NULL
 | ||
| ) DEFAULT CHARSET=utf8 COLLATE=utf8_bin ;
 | ||
| insert t1 values (1);
 | ||
| CREATE  FUNCTION `f1`(`P_DC_CD` VARBINARY(50), `P_SYS_DATE` DATETIME) RETURNS datetime
 | ||
| DETERMINISTIC
 | ||
| SQL SECURITY INVOKER
 | ||
| BEGIN
 | ||
| DECLARE V_SYS_DATE DATETIME;
 | ||
| SELECT now() AS LOC_DATE INTO V_SYS_DATE ;
 | ||
| RETURN v_sys_date ;
 | ||
| END $$
 | ||
| update t1 S
 | ||
| JOIN
 | ||
| (
 | ||
| SELECT CASE
 | ||
| WHEN DATE_FORMAT( f1('F01', NOW()) , '%Y%m%d') <= CLOSE_YMD
 | ||
| THEN '99991231'
 | ||
| 	     ELSE '' END ACCOUNT_APPLY_YYYYMMDD
 | ||
| FROM (
 | ||
| select case
 | ||
| when 'AP'='AP'
 | ||
|                    then ap_close_to
 | ||
| end AS CLOSE_YMD
 | ||
| from t2
 | ||
| ) A
 | ||
| ) X
 | ||
| SET S.CLOSE_YN = ''
 | ||
| where 1=1;
 | ||
| drop table t1,t2;
 | ||
| drop function f1;
 | ||
| #
 | ||
| # MDEV-16957: Server crashes in Field_iterator_natural_join::next
 | ||
| # upon 2nd execution of SP
 | ||
| #
 | ||
| CREATE TABLE t1 (a INT, b VARCHAR(32));
 | ||
| CREATE PROCEDURE sp() SELECT * FROM t1 AS t1x JOIN t1 AS t1y USING (c);
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'c' in 'FROM'
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'c' in 'FROM'
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'c' in 'FROM'
 | ||
| alter table t1 add column c int;
 | ||
| CALL sp;
 | ||
| c	a	b	a	b
 | ||
| DROP PROCEDURE sp;
 | ||
| DROP TABLE t1;
 | ||
| #
 | ||
| # MDEV-17055: Server crashes in find_order_in_list upon
 | ||
| # 2nd (3rd) execution of SP with UPDATE
 | ||
| #
 | ||
| CREATE TABLE t1 (a INT);
 | ||
| CREATE VIEW v1 AS SELECT * FROM t1;
 | ||
| CREATE TABLE t2 (c INT);
 | ||
| CREATE PROCEDURE sp() UPDATE v1 SET a = 1 ORDER BY a, b LIMIT 1;
 | ||
| LOCK TABLE t2 READ;
 | ||
| CALL sp;
 | ||
| ERROR HY000: Table 'v1' was not locked with LOCK TABLES
 | ||
| UNLOCK TABLES;
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'b' in 'ORDER BY'
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'b' in 'ORDER BY'
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'b' in 'ORDER BY'
 | ||
| DROP PROCEDURE sp;
 | ||
| CREATE PROCEDURE sp() UPDATE v1 SET a = 1 WHERE a=1 and b=2;
 | ||
| LOCK TABLE t2 READ;
 | ||
| CALL sp;
 | ||
| ERROR HY000: Table 'v1' was not locked with LOCK TABLES
 | ||
| UNLOCK TABLES;
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'b' in 'WHERE'
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'b' in 'WHERE'
 | ||
| CALL sp;
 | ||
| ERROR 42S22: Unknown column 'b' in 'WHERE'
 | ||
| DROP PROCEDURE sp;
 | ||
| DROP VIEW v1;
 | ||
| DROP TABLE t1, t2;
 | ||
| # End of 5.5 test
 | ||
| #
 | ||
| #  MDEV-7040: Crash in field_conv, memcpy_field_possible, part#2
 | ||
| #
 | ||
| create table t1 (
 | ||
| col1 bigint(20),
 | ||
| col2 char(1),
 | ||
| col3 char(2)
 | ||
| );
 | ||
| insert into t1 values (1,'a','a'), (2,'b','b');
 | ||
| create table t2 as select * from t1;
 | ||
| create table t3 as select * from t1;
 | ||
| create table t4 as select * from t1;
 | ||
| create table t5 as select * from t1;
 | ||
| create table t6 as select * from t1;
 | ||
| flush tables;
 | ||
| CREATE PROCEDURE p1()
 | ||
| begin
 | ||
| DECLARE _var1 bigint(20) UNSIGNED;
 | ||
| DECLARE _var2 CHAR(1) DEFAULT NULL;
 | ||
| DECLARE _var3 CHAR(1) DEFAULT NULL;
 | ||
| DECLARE _done BOOLEAN DEFAULT 0;
 | ||
| declare cur1 cursor for
 | ||
| select col1, col2, col3 
 | ||
| from t1 
 | ||
| where 
 | ||
| col1 in (select t2.col1 from t2 where t2.col2=t1.col2) or
 | ||
| col2 in (select t3.col3 from t3 where t3.col3=t1.col2) ;
 | ||
| DECLARE CONTINUE HANDLER FOR NOT FOUND SET _done = 1;
 | ||
| OPEN cur1;
 | ||
| set _var1 = (select _var1 from t4 limit 1);
 | ||
| set _var1 = (select _var1 from t5 limit 1);
 | ||
| set _var1 = (select _var1 from t6 limit 1);
 | ||
| label1:
 | ||
| LOOP
 | ||
| SET _done = 0;
 | ||
| FETCH cur1 INTO _var1, _var2, _var3;
 | ||
| IF _done THEN
 | ||
| LEAVE label1;
 | ||
| END IF;
 | ||
| END LOOP label1;
 | ||
| CLOSE cur1;
 | ||
| end|
 | ||
| set @tmp_toc= @@table_open_cache;
 | ||
| set @tmp_tdc= @@table_definition_cache;
 | ||
| set global table_open_cache=10;
 | ||
| set global table_definition_cache=1;
 | ||
| Warnings:
 | ||
| Warning	1292	Truncated incorrect table_definition_cache value: '1'
 | ||
| call p1();
 | ||
| set global table_open_cache= @tmp_toc;
 | ||
| set global table_definition_cache= @tmp_tdc;
 | ||
| drop procedure p1;
 | ||
| drop table t1,t2,t3,t4,t5,t6;
 | ||
| #
 | ||
| # MDEV-11935: Queries in stored procedures with and
 | ||
| # EXISTS(SELECT * FROM VIEW) crashes and closes hte conneciton.
 | ||
| #
 | ||
| CREATE TABLE ANY_TABLE (
 | ||
| ENTITY_UID    BIGINT NOT NULL
 | ||
| );
 | ||
| CREATE TABLE SECURITY_PATH(
 | ||
| origid BIGINT UNSIGNED NOT NULL,
 | ||
| destid BIGINT UNSIGNED NOT NULL,
 | ||
| KEY (destid)
 | ||
| );
 | ||
| CREATE VIEW ENTITY_ACCESS (
 | ||
| ENTITY_UID,
 | ||
| OWNER_UID
 | ||
| ) AS
 | ||
| SELECT SP1.origid,
 | ||
| SP2.destid
 | ||
| FROM SECURITY_PATH SP1
 | ||
| JOIN SECURITY_PATH SP2 ON SP1.destid = SP2.origid
 | ||
| ;
 | ||
| CREATE PROCEDURE SP_EXAMPLE_SELECT ()
 | ||
| BEGIN
 | ||
| SELECT *
 | ||
| FROM ANY_TABLE AT1
 | ||
| WHERE EXISTS ( SELECT *
 | ||
| FROM ENTITY_ACCESS EA
 | ||
| WHERE AT1.ENTITY_UID = EA.ENTITY_UID
 | ||
| AND   EA.OWNER_UID IS NULL );
 | ||
| END
 | ||
| //
 | ||
| CALL SP_EXAMPLE_SELECT ();
 | ||
| ENTITY_UID
 | ||
| CALL SP_EXAMPLE_SELECT ();
 | ||
| ENTITY_UID
 | ||
| drop procedure SP_EXAMPLE_SELECT;
 | ||
| drop view ENTITY_ACCESS;
 | ||
| drop table ANY_TABLE, SECURITY_PATH;
 | ||
| # End of 10.0 test
 | ||
| CREATE FUNCTION f(f1 VARCHAR(64) COLLATE latin1_german2_ci)
 | ||
| RETURNS VARCHAR(64)
 | ||
| BEGIN
 | ||
| RETURN 'str';
 | ||
| END|
 | ||
| DROP FUNCTION f|
 | ||
| CREATE FUNCTION f(f1 VARCHAR(64))
 | ||
| RETURNS VARCHAR(64) COLLATE latin1_german2_ci
 | ||
| BEGIN
 | ||
| RETURN 'str';
 | ||
| END|
 | ||
| DROP FUNCTION f|
 | ||
| CREATE FUNCTION f(f1 VARCHAR(64))
 | ||
| RETURNS VARCHAR(64)
 | ||
| BEGIN
 | ||
| DECLARE f2 VARCHAR(64) COLLATE latin1_german2_ci;
 | ||
| RETURN 'str';
 | ||
| END|
 | ||
| DROP FUNCTION f|
 | ||
| #
 | ||
| # MDEV-7023: Error 2027: Malformed packet and assertion
 | ||
| # `field_types == 0 || field_types[field_pos] == MYSQL_TYPE_INT24 ||
 | ||
| #field_types[field_pos] == MYSQL_TYPE_LONG' failure in
 | ||
| #Protocol_text::store_long
 | ||
| #
 | ||
| create table t1 (i int);
 | ||
| create table t2 (i int);
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze insert into t1 values (1); 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze insert t1 select * from t2; 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze delete from t1; 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze delete t1 from t1,t2; 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze update t1 set i=1; 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze update t1,t2 set i=1; 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze replace t1 set i=1; 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| create function f() returns int 
 | ||
| begin 
 | ||
| analyze replace t1 select * from t2; 
 | ||
| return 1; 
 | ||
| end |
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| drop table t1,t2;
 | ||
| #
 | ||
| # MDEV-11584: GRANT inside an SP does not work well on 2nd execution
 | ||
| #
 | ||
| CREATE PROCEDURE sp1()
 | ||
| GRANT ALL PRIVILEGES ON *.* TO 'foo'@'%' IDENTIFIED BY 'pass';
 | ||
| CALL sp1();
 | ||
| CALL sp1();
 | ||
| drop user 'foo'@'%';
 | ||
| drop procedure sp1;
 | ||
| #
 | ||
| # MDEV-10972: Insert from select / view / union --
 | ||
| # repeatable crash in 10.1, 10.2 Linux/Mac/Windows
 | ||
| #
 | ||
| create table t (id int auto_increment primary key);
 | ||
| insert into t values (9494),(9495),(9496),(9497),(9498),(9499),(9500),(9501),(9502),(9503);
 | ||
| create VIEW v AS
 | ||
| select id from t
 | ||
| union
 | ||
| select id from t
 | ||
| ;
 | ||
| create procedure p()
 | ||
| insert into tmp_t select t.id from (
 | ||
| select id from v
 | ||
| union
 | ||
| select id from v
 | ||
| ) sq
 | ||
| inner join t on (sq.id = t.id);
 | ||
| CALL p();
 | ||
| ERROR 42S02: Table 'test.tmp_t' doesn't exist
 | ||
| create table tmp_t (id int null);
 | ||
| CALL p();
 | ||
| drop procedure p;
 | ||
| drop view v;
 | ||
| drop table t, tmp_t;
 | ||
| #
 | ||
| # MDEV-13936: Server crashes in Time_and_counter_tracker::incr_loops
 | ||
| #
 | ||
| CREATE TABLE t1 (i INT);
 | ||
| CREATE VIEW v1 AS SELECT * FROM t1 WHERE RAND() > 0.5;
 | ||
| CREATE FUNCTION f1() RETURNS INT RETURN ( SELECT MAX(i) FROM v1 );
 | ||
| REPLACE INTO v1 VALUES (f1());
 | ||
| ERROR HY000: The target table v1 of the INSERT is not insertable-into
 | ||
| SET @aux = f1();
 | ||
| DROP FUNCTION f1;
 | ||
| DROP VIEW v1;
 | ||
| DROP TABLE t1;
 | ||
| #
 | ||
| # MDEV-14857: problem with 10.2.11 server crashing when
 | ||
| # executing stored procedure
 | ||
| #
 | ||
| SET max_sp_recursion_depth=10;
 | ||
| CREATE TABLE t1 (a INT);
 | ||
| CREATE TABLE t2 (b INT);
 | ||
| CREATE PROCEDURE proc_0()
 | ||
| BEGIN
 | ||
| CALL empty_1();
 | ||
| CALL proc_1();
 | ||
| END ||
 | ||
| CREATE PROCEDURE proc_1()
 | ||
| BEGIN
 | ||
| CALL proc_2();
 | ||
| CALL proc_3();
 | ||
| CALL proc_4();
 | ||
| CALL proc_5();
 | ||
| END ||
 | ||
| CREATE PROCEDURE proc_2()
 | ||
| CALL proc_6();
 | ||
| ||
 | ||
| CREATE PROCEDURE proc_3()
 | ||
| BEGIN
 | ||
| CALL empty_2();
 | ||
| CALL empty_3();
 | ||
| END ||
 | ||
| CREATE PROCEDURE proc_4()
 | ||
| CALL proc_7();
 | ||
| ||
 | ||
| CREATE PROCEDURE proc_5()
 | ||
| CALL proc_select();
 | ||
| ||
 | ||
| CREATE PROCEDURE proc_6()
 | ||
| BEGIN
 | ||
| CALL empty_4();
 | ||
| CALL empty_5();
 | ||
| CALL empty_6();
 | ||
| CALL empty_7();
 | ||
| CALL proc_8();
 | ||
| END ||
 | ||
| CREATE PROCEDURE proc_7()
 | ||
| CALL proc_9('foo');
 | ||
| ||
 | ||
| CREATE PROCEDURE proc_8()
 | ||
| CALL proc_10();
 | ||
| ||
 | ||
| CREATE PROCEDURE proc_9(IN opt VARCHAR(40))
 | ||
| IF LEFT(opt,1) <> '_' THEN
 | ||
| CALL proc_11();
 | ||
| END IF;
 | ||
| ||
 | ||
| CREATE PROCEDURE proc_10()
 | ||
| CALL proc_12();
 | ||
| ||
 | ||
| CREATE PROCEDURE proc_11()
 | ||
| BEGIN
 | ||
| CALL empty_8();
 | ||
| CALL empty_9();
 | ||
| CALL empty_10();
 | ||
| CALL proc_13();
 | ||
| END ||
 | ||
| CREATE PROCEDURE proc_12()
 | ||
| BEGIN
 | ||
| CALL empty_11();
 | ||
| CALL empty_12();
 | ||
| CALL empty_13();
 | ||
| END ||
 | ||
| CREATE PROCEDURE proc_13()
 | ||
| BEGIN
 | ||
| CALL proc_9('_bar');
 | ||
| CALL empty_14();
 | ||
| END ||
 | ||
| CREATE PROCEDURE empty_1() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_2() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_3() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_4() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_5() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_6() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_7() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_8() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_9() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_10() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_11() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_12() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_13() BEGIN END ;
 | ||
| CREATE PROCEDURE empty_14() BEGIN END ;
 | ||
| CREATE PROCEDURE proc_select()
 | ||
| SELECT * FROM t1 WHERE NOT EXISTS ( SELECT * FROM t2)
 | ||
| ;
 | ||
| CALL proc_0();
 | ||
| a
 | ||
| DROP PROCEDURE empty_1;
 | ||
| DROP PROCEDURE empty_2;
 | ||
| DROP PROCEDURE empty_3;
 | ||
| DROP PROCEDURE empty_4;
 | ||
| DROP PROCEDURE empty_5;
 | ||
| DROP PROCEDURE empty_6;
 | ||
| DROP PROCEDURE empty_7;
 | ||
| DROP PROCEDURE empty_8;
 | ||
| DROP PROCEDURE empty_9;
 | ||
| DROP PROCEDURE empty_10;
 | ||
| DROP PROCEDURE empty_11;
 | ||
| DROP PROCEDURE empty_12;
 | ||
| DROP PROCEDURE empty_13;
 | ||
| DROP PROCEDURE empty_14;
 | ||
| DROP PROCEDURE proc_0;
 | ||
| DROP PROCEDURE proc_1;
 | ||
| DROP PROCEDURE proc_2;
 | ||
| DROP PROCEDURE proc_3;
 | ||
| DROP PROCEDURE proc_4;
 | ||
| DROP PROCEDURE proc_5;
 | ||
| DROP PROCEDURE proc_6;
 | ||
| DROP PROCEDURE proc_7;
 | ||
| DROP PROCEDURE proc_8;
 | ||
| DROP PROCEDURE proc_9;
 | ||
| DROP PROCEDURE proc_10;
 | ||
| DROP PROCEDURE proc_11;
 | ||
| DROP PROCEDURE proc_12;
 | ||
| DROP PROCEDURE proc_13;
 | ||
| DROP PROCEDURE proc_select;
 | ||
| DROP TABLE t1, t2;
 | ||
| SET max_sp_recursion_depth=default;
 | ||
| #
 | ||
| # MDEV-15347: Valgrind or ASAN errors in mysql_make_view on query
 | ||
| # from information_schema
 | ||
| #
 | ||
| CREATE VIEW v AS SELECT 1;
 | ||
| CREATE FUNCTION f() RETURNS INT RETURN 1;
 | ||
| SELECT * FROM INFORMATION_SCHEMA.TABLES JOIN INFORMATION_SCHEMA.PARAMETERS
 | ||
| UNION
 | ||
| SELECT * FROM INFORMATION_SCHEMA.TABLES JOIN INFORMATION_SCHEMA.PARAMETERS;
 | ||
| DROP FUNCTION f;
 | ||
| DROP VIEW v;
 | ||
| #
 | ||
| # MDEV-17963: Assertion `field_pos < field_count' failed in Protocol_text::store,
 | ||
| # Assertion `field_handlers == 0 || field_pos < field_count'
 | ||
| #
 | ||
| CREATE TABLE t1 (ct time);
 | ||
| INSERT INTO t1 VALUES ('16:11:28');
 | ||
| CREATE FUNCTION f1 () RETURNS varchar(100)
 | ||
| BEGIN
 | ||
| DECLARE xxx varchar(100);
 | ||
| ANALYZE SELECT sum(ct) FROM t1 INTO xxx ;
 | ||
| RETURN xxx;
 | ||
| END|
 | ||
| ERROR 0A000: Not allowed to return a result set from a function
 | ||
| drop table t1;
 | ||
| #End of 10.1 tests
 | ||
| #
 | ||
| # MDEV-11081: CURSOR for query with GROUP BY
 | ||
| #
 | ||
| CREATE TABLE t1 (name VARCHAR(10), value INT);
 | ||
| INSERT INTO t1 VALUES ('b',1);
 | ||
| INSERT INTO t1 VALUES ('b',1);
 | ||
| INSERT INTO t1 VALUES ('c',1);
 | ||
| INSERT INTO t1 VALUES ('a',1);
 | ||
| INSERT INTO t1 VALUES ('a',1);
 | ||
| INSERT INTO t1 VALUES ('a',1);
 | ||
| CREATE PROCEDURE p1 ()
 | ||
| BEGIN
 | ||
| DECLARE done INT DEFAULT FALSE;
 | ||
| DECLARE v_name VARCHAR(10);
 | ||
| DECLARE v_total INT;
 | ||
| DECLARE c CURSOR FOR
 | ||
| SELECT name, SUM(value) AS total FROM t1 GROUP BY name;
 | ||
| DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 | ||
| OPEN c;
 | ||
| read_loop:
 | ||
| LOOP
 | ||
| FETCH c INTO v_name, v_total;
 | ||
| IF done THEN
 | ||
| LEAVE read_loop;
 | ||
| END IF;
 | ||
| SELECT v_name, v_total;
 | ||
| END LOOP;
 | ||
| CLOSE c;
 | ||
| END;
 | ||
| |
 | ||
| CALL p1();
 | ||
| v_name	v_total
 | ||
| a	3
 | ||
| v_name	v_total
 | ||
| b	2
 | ||
| v_name	v_total
 | ||
| c	1
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP TABLE t1;
 | ||
| #
 | ||
| # MDEV-13346: CURSOR a query with GROUP BY using derived table
 | ||
| #
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE c CURSOR FOR
 | ||
| SELECT
 | ||
| IFNULL(NULL,1) AS col
 | ||
| FROM
 | ||
| ( select 1 as id ) AS t
 | ||
| GROUP BY t.id
 | ||
| ;
 | ||
| OPEN c;
 | ||
| END
 | ||
| |
 | ||
| CALL p1();
 | ||
| DROP PROCEDURE p1;
 | ||
| #
 | ||
| # MDEV-15057 Crash when using an unknown identifier as an SP parameter
 | ||
| #
 | ||
| CREATE OR REPLACE PROCEDURE p1 (a VARCHAR(10)) SELECT 1;
 | ||
| CALL p1(a);
 | ||
| ERROR 42S22: Unknown column 'a' in 'CALL'
 | ||
| drop procedure p1;
 | ||
| CREATE OR REPLACE PROCEDURE p1 (a VARCHAR(10)) SELECT a|
 | ||
| CREATE OR REPLACE PROCEDURE p2 ()
 | ||
| BEGIN
 | ||
| DECLARE name VARCHAR(10);
 | ||
| SET name="hello";
 | ||
| call p1(name);
 | ||
| END|
 | ||
| CREATE OR REPLACE PROCEDURE p3 ()
 | ||
| BEGIN
 | ||
| DECLARE name VARCHAR(10);
 | ||
| SET name="hello";
 | ||
| call p1(name2);
 | ||
| END|
 | ||
| ERROR 42000: Undeclared variable: name2
 | ||
| call p2();
 | ||
| a
 | ||
| hello
 | ||
| drop procedure p1;
 | ||
| drop procedure p2;
 | ||
| #
 | ||
| # MDEV-15328: MariaDB 10.2.13 Crashes upon CALL PROCEDURE PARAM
 | ||
| # LAST_INSERT_ID ()
 | ||
| # (part 1, part 2 is in query_cache.test)
 | ||
| #
 | ||
| CREATE PROCEDURE foo ( IN i INT UNSIGNED ) BEGIN END;
 | ||
| CALL foo( LAST_INSERT_ID() );
 | ||
| DROP PROCEDURE foo;
 | ||
| #
 | ||
| # MDEV-15870 Using aggregate and window function in unexpected places can crash the server
 | ||
| #
 | ||
| CREATE PROCEDURE p1 (a TEXT) BEGIN END;
 | ||
| CALL p1(RANK() OVER (ORDER BY 1));
 | ||
| ERROR HY000: Window function is allowed only in SELECT list and ORDER BY clause
 | ||
| CALL p1(ROW_NUMBER() OVER ());
 | ||
| ERROR HY000: Window function is allowed only in SELECT list and ORDER BY clause
 | ||
| CALL p1(SUM(1));
 | ||
| ERROR HY000: Invalid use of group function
 | ||
| DROP PROCEDURE p1;
 | ||
| #
 | ||
| # MDEV-16311 Server crash when using a NAME_CONST() with a CURSOR
 | ||
| #
 | ||
| SET sql_mode=STRICT_ALL_TABLES;
 | ||
| CREATE TABLE t1 (a INT);
 | ||
| INSERT INTO t1 VALUES (10);
 | ||
| BEGIN NOT ATOMIC
 | ||
| DECLARE a INT;
 | ||
| DECLARE c CURSOR FOR SELECT NAME_CONST('x','y') FROM t1;
 | ||
| OPEN c;
 | ||
| FETCH c INTO a;
 | ||
| CLOSE c;
 | ||
| END;
 | ||
| $$
 | ||
| ERROR 22007: Incorrect integer value: 'y' for column ``.``.`a` at row 1
 | ||
| DROP TABLE t1;
 | ||
| SET sql_mode=DEFAULT;
 | ||
| #
 | ||
| # MDEV-24220: error when opening a table for the second call of SP
 | ||
| #
 | ||
| CREATE TABLE t1 (a INT, b INT);
 | ||
| INSERT INTO t1 VALUES (1,1),(2,2);
 | ||
| CREATE VIEW v1 AS SELECT MAX(a) as f FROM t1;
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| SELECT * FROM v1;
 | ||
| END $
 | ||
| CALL p1;
 | ||
| f
 | ||
| 2
 | ||
| ALTER TABLE t1 DROP a;
 | ||
| CALL p1;
 | ||
| ERROR HY000: View 'test.v1' references invalid table(s) or column(s) or function(s) or definer/invoker of view lack rights to use them
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP VIEW v1;
 | ||
| DROP TABLE t1;
 | ||
| #
 | ||
| # BUG#30366310: USING A FUNCTION TO ASSIGN DEFAULT VALUES TO
 | ||
| # 2 OR MORE VARIABLES CRASHES SERVER
 | ||
| #
 | ||
| create function f1() returns bigint return now()-1|
 | ||
| create procedure p1()
 | ||
| begin
 | ||
| declare b, c bigint default f1();
 | ||
| select b-c;
 | ||
| end|
 | ||
| call p1()|
 | ||
| b-c
 | ||
| 0
 | ||
| drop procedure p1|
 | ||
| drop function f1|
 | ||
| #
 | ||
| # MDEV-24827: MariaDB 10.5.5 crash (sig 11) during a SELECT
 | ||
| #
 | ||
| CREATE TABLE t1 (c1 INT PRIMARY KEY, c2 INT);
 | ||
| CREATE TABLE t2 (c1 INT PRIMARY KEY, c2 INT, KEY idx_c2(c2));
 | ||
| INSERT INTO t1 (c1, c2) SELECT seq, seq FROM seq_1_to_10000;
 | ||
| INSERT INTO t2 (c1, c2) SELECT seq, seq FROM seq_1_to_20000;
 | ||
| CREATE OR REPLACE PROCEDURE p1()
 | ||
| begin
 | ||
| DECLARE done INT DEFAULT FALSE;
 | ||
| DECLARE a INT;
 | ||
| DECLARE cur1 CURSOR FOR
 | ||
| SELECT t2.c1 AS c1 FROM t1 LEFT JOIN t2 ON t1.c1 = t2.c1
 | ||
| WHERE EXISTS (SELECT 1 FROM t1 WHERE c2 = -1) ORDER BY c1;
 | ||
| DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 | ||
| OPEN cur1;
 | ||
| read_loop: LOOP
 | ||
| FETCH cur1 INTO a;
 | ||
| IF done THEN
 | ||
| LEAVE read_loop;
 | ||
| END IF;
 | ||
| END LOOP;
 | ||
| CLOSE cur1;
 | ||
| END $
 | ||
| CALL p1();
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP TABLE t1;
 | ||
| DROP TABLE t2;
 | ||
| #End of 10.2 tests
 | ||
| #
 | ||
| # MDEV-12007 Allow ROW variables as a cursor FETCH target
 | ||
| #
 | ||
| # The cursor and the ROW variable in FETCH must have the same number of fields
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE done INT DEFAULT FALSE;
 | ||
| DECLARE rec ROW(aa INT, bb VARCHAR(32), cc INT);
 | ||
| DECLARE cur CURSOR FOR SELECT 10 AS a,'b10' AS b;
 | ||
| DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 | ||
| OPEN cur;
 | ||
| read_loop:
 | ||
| LOOP
 | ||
| FETCH cur INTO rec;
 | ||
| IF done THEN
 | ||
| LEAVE read_loop;
 | ||
| END IF;
 | ||
| END LOOP;
 | ||
| CLOSE cur;
 | ||
| END;
 | ||
| $$
 | ||
| CALL p1();
 | ||
| ERROR HY000: Incorrect number of FETCH variables
 | ||
| DROP PROCEDURE p1;
 | ||
| # Multiple ROW variables in FETCH
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE done INT DEFAULT FALSE;
 | ||
| DECLARE rec1 ROW(aa INT);
 | ||
| DECLARE rec2 ROW(aa INT);
 | ||
| DECLARE cur CURSOR FOR SELECT 10 AS a, 20 AS b;
 | ||
| DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 | ||
| OPEN cur;
 | ||
| read_loop:
 | ||
| LOOP
 | ||
| FETCH cur INTO rec1, rec2;
 | ||
| IF done THEN
 | ||
| LEAVE read_loop;
 | ||
| END IF;
 | ||
| END LOOP;
 | ||
| CLOSE cur;
 | ||
| END;
 | ||
| $$
 | ||
| CALL p1();
 | ||
| ERROR 21000: Operand should contain 1 column(s)
 | ||
| DROP PROCEDURE p1;
 | ||
| # A complete working example
 | ||
| CREATE TABLE t1 (a INT, b VARCHAR(32));
 | ||
| INSERT INTO t1 VALUES (10,'b10');
 | ||
| INSERT INTO t1 VALUES (20,'b20');
 | ||
| INSERT INTO t1 VALUES (30,'b30');
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE done INT DEFAULT FALSE;
 | ||
| DECLARE rec ROW(aa INT, bb VARCHAR(32));
 | ||
| DECLARE cur CURSOR FOR SELECT a,b FROM t1;
 | ||
| DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 | ||
| OPEN cur;
 | ||
| read_loop:
 | ||
| LOOP
 | ||
| FETCH cur INTO rec;
 | ||
| IF done THEN
 | ||
| LEAVE read_loop;
 | ||
| END IF;
 | ||
| SELECT CONCAT('rec=(',rec.aa,',',rec.bb,')') AS c;
 | ||
| END LOOP;
 | ||
| CLOSE cur;
 | ||
| END;
 | ||
| $$
 | ||
| CALL p1();
 | ||
| c
 | ||
| rec=(10,b10)
 | ||
| c
 | ||
| rec=(20,b20)
 | ||
| c
 | ||
| rec=(30,b30)
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP TABLE t1;
 | ||
| # A ROW variable with a single field
 | ||
| CREATE PROCEDURE p1()
 | ||
| BEGIN
 | ||
| DECLARE done INT DEFAULT FALSE;
 | ||
| DECLARE rec ROW(aa INT);
 | ||
| DECLARE cur CURSOR FOR SELECT 10 AS a UNION SELECT 20;
 | ||
| DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 | ||
| OPEN cur;
 | ||
| read_loop:
 | ||
| LOOP
 | ||
| FETCH cur INTO rec;
 | ||
| IF done THEN
 | ||
| LEAVE read_loop;
 | ||
| END IF;
 | ||
| SELECT CONCAT('rec=(',rec.aa,')') AS c;
 | ||
| END LOOP;
 | ||
| CLOSE cur;
 | ||
| END;
 | ||
| $$
 | ||
| CALL p1();
 | ||
| c
 | ||
| rec=(10)
 | ||
| c
 | ||
| rec=(20)
 | ||
| DROP PROCEDURE p1;
 | ||
| #
 | ||
| # MDEV-14228 MariaDB crashes with function
 | ||
| #
 | ||
| CREATE TABLE t1 (c VARCHAR(16), KEY(c));
 | ||
| INSERT INTO t1 VALUES ('foo');
 | ||
| CREATE FUNCTION f1() RETURNS VARCHAR(16)
 | ||
| BEGIN
 | ||
| DECLARE v VARCHAR(16);
 | ||
| FOR v IN (SELECT DISTINCT c FROM t1)
 | ||
| DO
 | ||
| IF (v = 'bar') THEN
 | ||
| SELECT 1 INTO @a;
 | ||
| END IF;
 | ||
| END FOR;
 | ||
| RETURN 'qux';
 | ||
| END $$
 | ||
| SELECT f1();
 | ||
| ERROR HY000: Illegal parameter data types row and varchar for operation '='
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS VARCHAR(16)
 | ||
| BEGIN
 | ||
| DECLARE v ROW TYPE OF t1;
 | ||
| IF v = 'bar' THEN
 | ||
| RETURN 'eq';
 | ||
| END IF;
 | ||
| RETURN 'ne';
 | ||
| END $$
 | ||
| SELECT f1();
 | ||
| ERROR HY000: Illegal parameter data types row and varchar for operation '='
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS VARCHAR(16)
 | ||
| BEGIN
 | ||
| DECLARE v ROW(a INT);
 | ||
| IF v = 'bar' THEN
 | ||
| RETURN 'eq';
 | ||
| END IF;
 | ||
| RETURN 'ne';
 | ||
| END $$
 | ||
| SELECT f1();
 | ||
| ERROR HY000: Illegal parameter data types row and varchar for operation '='
 | ||
| DROP FUNCTION f1;
 | ||
| DROP TABLE t1;
 | ||
| BEGIN NOT ATOMIC
 | ||
| DECLARE v ROW(a INT);
 | ||
| SELECT v IN ('a','b');
 | ||
| END $$
 | ||
| ERROR HY000: Illegal parameter data types row and varchar for operation 'in'
 | ||
| BEGIN NOT ATOMIC
 | ||
| DECLARE v ROW(a INT);
 | ||
| SELECT 'a' IN (v,'b');
 | ||
| END $$
 | ||
| ERROR HY000: Illegal parameter data types varchar and row for operation 'in'
 | ||
| BEGIN NOT ATOMIC
 | ||
| DECLARE v ROW(a INT);
 | ||
| SELECT 'a' IN ('b',v);
 | ||
| END $$
 | ||
| ERROR HY000: Illegal parameter data types varchar and row for operation 'in'
 | ||
| #
 | ||
| # MDEV-15112 Inconsistent evaluation of spvariable=0 in strict mode
 | ||
| #
 | ||
| SET sql_mode=STRICT_ALL_TABLES;
 | ||
| CREATE OR REPLACE TABLE t1 (e TIMESTAMP(6));
 | ||
| INSERT INTO t1 VALUES ('2001-01-01 10:20:30');
 | ||
| CREATE FUNCTION f1(a VARBINARY(255))
 | ||
| RETURNS INT
 | ||
| DETERMINISTIC
 | ||
| BEGIN
 | ||
| RETURN a = timestamp'2038-01-19 03:14:07.999999'
 | ||
|       OR a = 0;
 | ||
| END
 | ||
| $$
 | ||
| CREATE FUNCTION f2(a VARBINARY(255))
 | ||
| RETURNS INT
 | ||
| DETERMINISTIC
 | ||
| BEGIN
 | ||
| RETURN a = 0;
 | ||
| END
 | ||
| $$
 | ||
| CREATE OR REPLACE FUNCTION f3(a VARBINARY(255))
 | ||
| RETURNS INT
 | ||
| DETERMINISTIC
 | ||
| BEGIN
 | ||
| RETURN a = timestamp'2038-01-19 03:14:07.999999'
 | ||
|       OR a = sleep(0);
 | ||
| END
 | ||
| $$
 | ||
| SELECT f1(e) FROM t1;
 | ||
| ERROR 22007: Truncated incorrect DECIMAL value: '2001-01-01 10:20:30.000000'
 | ||
| SELECT f2(e) FROM t1;
 | ||
| ERROR 22007: Truncated incorrect DECIMAL value: '2001-01-01 10:20:30.000000'
 | ||
| SELECT f3(e) FROM t1;
 | ||
| ERROR 22007: Truncated incorrect DECIMAL value: '2001-01-01 10:20:30.000000'
 | ||
| DROP FUNCTION f1;
 | ||
| DROP FUNCTION f2;
 | ||
| DROP FUNCTION f3;
 | ||
| DROP TABLE t1;
 | ||
| # Test affected rows from an sp
 | ||
| create table t1 (a int);
 | ||
| create procedure p1()
 | ||
| begin
 | ||
| insert into t1 values(1);
 | ||
| insert into t1 values(2);
 | ||
| end;
 | ||
| $$
 | ||
| create procedure p2()
 | ||
| begin
 | ||
| insert into t1 values(1);
 | ||
| call p1();
 | ||
| select row_count();
 | ||
| insert into t1 values(2);
 | ||
| insert into t1 values(2);
 | ||
| end;
 | ||
| $$
 | ||
| CALL p2();
 | ||
| row_count()
 | ||
| 2
 | ||
| affected rows: 1
 | ||
| affected rows: 5
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP PROCEDURE p2;
 | ||
| drop table t1;
 | ||
| #
 | ||
| # MDEV-15957 Unexpected "Data too long" when doing CREATE..SELECT with stored functions
 | ||
| #
 | ||
| CREATE TABLE t1 (a INT(3));
 | ||
| INSERT INTO t1 VALUES (-999);
 | ||
| CREATE FUNCTION f1(a INT(3)) RETURNS INT(3) RETURN a;
 | ||
| CREATE TABLE t2 AS SELECT CONCAT(a) AS c1, CONCAT(COALESCE(a)) AS c2, CONCAT(f1(a)) AS c3 FROM t1;
 | ||
| SHOW CREATE TABLE t2;
 | ||
| Table	Create Table
 | ||
| t2	CREATE TABLE `t2` (
 | ||
|   `c1` varchar(11) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c2` varchar(11) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c3` varchar(11) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1,t2;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS TINYTEXT CHARACTER SET latin1 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` tinytext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c2` tinytext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c3` varchar(255) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS TEXT CHARACTER SET latin1 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` text CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c2` text CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c3` text CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS MEDIUMTEXT CHARACTER SET latin1 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` mediumtext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c2` mediumtext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c3` mediumtext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS LONGTEXT CHARACTER SET latin1 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` longtext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c2` longtext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
 | ||
|   `c3` longtext CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS TINYTEXT CHARACTER SET utf8 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` tinytext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c2` text CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c3` varchar(255) CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS TEXT CHARACTER SET utf8 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` text CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c2` mediumtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c3` mediumtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS MEDIUMTEXT CHARACTER SET utf8 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` mediumtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c2` longtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c3` longtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS LONGTEXT CHARACTER SET utf8 RETURN '';
 | ||
| CREATE TABLE t1 AS SELECT f1() AS c1, COALESCE(f1()) AS c2, CONCAT(f1()) AS c3;
 | ||
| SHOW CREATE TABLE t1;
 | ||
| Table	Create Table
 | ||
| t1	CREATE TABLE `t1` (
 | ||
|   `c1` longtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c2` longtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL,
 | ||
|   `c3` longtext CHARACTER SET utf8mb3 COLLATE utf8mb3_uca1400_ai_ci DEFAULT NULL
 | ||
| ) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_uca1400_ai_ci
 | ||
| DROP TABLE t1;
 | ||
| DROP FUNCTION f1;
 | ||
| #
 | ||
| # MDEV-16036: Debug assertion failed in resignal on create
 | ||
| # temporary table 
 | ||
| #
 | ||
| set @save_sql_mode= @@sql_mode;
 | ||
| set sql_mode='ORACLE';
 | ||
| CREATE or replace procedure p4()
 | ||
| AS
 | ||
| CONTINUE HANDLER FOR SQLWARNING
 | ||
| BEGIN
 | ||
| NULL;
 | ||
| END;
 | ||
| EXIT HANDLER FOR OTHERS -- SQLEXCEPTION
 | ||
| BEGIN
 | ||
| GET DIAGNOSTICS CONDITION 1 @sqlstate = RETURNED_SQLSTATE, @errno = MYSQL_ERRNO, @text = MESSAGE_TEXT;
 | ||
| SELECT @sqlstate, @errno, @text;
 | ||
| SHOW WARNINGS;
 | ||
| RESIGNAL;  -- cause DBG_ASSERT failed
 | ||
| END;
 | ||
| BEGIN
 | ||
| CREATE TEMPORARY TABLE IF NOT EXISTS t1(origine VARCHAR2(10) NOT NULL);
 | ||
| END
 | ||
| /
 | ||
| call p4();
 | ||
| call p4();
 | ||
| @sqlstate	@errno	@text
 | ||
| 42S01	1050	Table 't1' already exists
 | ||
| Level	Code	Message
 | ||
| Note	1050	Table 't1' already exists
 | ||
| Warnings:
 | ||
| Note	1050	Table 't1' already exists
 | ||
| drop procedure p4;
 | ||
| drop table t1;
 | ||
| set @@sql_mode=@save_sql_mode;
 | ||
| set @@global.userstat= @save_userstat;
 | ||
| #
 | ||
| # MDEV-17363 Compressed columns cannot be restored from dump
 | ||
| # COMPRESSED conflicted between data type and SP label,
 | ||
| # so it's not allowed as an SP label any more.
 | ||
| #
 | ||
| CREATE FUNCTION f1() RETURNS TEXT COMPRESSED
 | ||
| BEGIN
 | ||
| RETURN '';
 | ||
| END;
 | ||
| $$
 | ||
| SHOW CREATE FUNCTION f1;
 | ||
| Function	sql_mode	Create Function	character_set_client	collation_connection	Database Collation
 | ||
| f1	STRICT_ALL_TABLES	CREATE DEFINER=`root`@`localhost` FUNCTION `f1`() RETURNS text  COMPRESSED CHARSET utf8mb4 COLLATE utf8mb4_uca1400_ai_ci
 | ||
| BEGIN
 | ||
| RETURN '';
 | ||
| END	latin1	latin1_swedish_ci	utf8mb4_uca1400_ai_ci
 | ||
| DROP FUNCTION f1;
 | ||
| CREATE FUNCTION f1() RETURNS TEXT
 | ||
| COMPRESSED:
 | ||
| BEGIN
 | ||
| RETURN '';
 | ||
| END;
 | ||
| $$
 | ||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near ':
 | ||
| BEGIN
 | ||
| RETURN '';
 | ||
| END' at line 2
 | ||
| #
 | ||
| # MDEV-28220: Assert failure in sp_head::~sp_head on parsing a syntax incorrect statement CREATE SEQUENCE ... RESTART inside CREATE PROCEDURE/CREATE FUNCTION
 | ||
| 
 | ||
| # Specifying the RESTART clause for the statement CREATE SEQUENCE is a syntax error.
 | ||
| # Check that CREATE PROCEDURE doesn't crash server if the statement
 | ||
| # CREATE SEQUNCE ... RESTART is specified in its body.
 | ||
| #
 | ||
| CREATE PROCEDURE sp1() CREATE SEQUENCE s1 START WITH 300 INCREMENT BY 30 RESTART;
 | ||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'RESTART' at line 1
 | ||
| # CREATE SEQUNCE ... RESTART and CREATE SEQUNCE ... RESTART WITH ... are
 | ||
| # handled by different grammar rules, so check the both cases.
 | ||
| CREATE PROCEDURE sp1() CREATE SEQUENCE s1 START WITH 300 INCREMENT BY 30 RESTART WITH 100;
 | ||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'RESTART' at line 1
 | ||
| # End of 10.3 tests
 | ||
| #
 | ||
| # Start of 10.4 tests
 | ||
| #
 | ||
| #
 | ||
| # MDEV-19637 Crash on an SP variable assignment to a wrong subselect
 | ||
| #
 | ||
| BEGIN NOT ATOMIC
 | ||
| DECLARE a INT;
 | ||
| SET a=(SELECT 1 FROM DUAL UNION SELECT HIGH_PRIORITY 2 FROM DUAL);
 | ||
| END;
 | ||
| $$
 | ||
| ERROR 42000: Incorrect usage/placement of 'HIGH_PRIORITY'
 | ||
| #
 | ||
| # MDEV-21173: Assertion `m_thd == __null' failed in sp_head::~sp_head
 | ||
| #
 | ||
| CREATE TABLE t1 (a INT);
 | ||
| CREATE PROCEDURE p1() SELECT 1 FROM t1 PROCEDURE ANALYSE( 10, (SELECT a FROM t1));
 | ||
| ERROR 42000: PROCEDURE does not support subqueries or stored functions
 | ||
| DROP TABLE t1;
 | ||
| #
 | ||
| # MDEV-23902: MariaDB crash on calling function
 | ||
| #
 | ||
| CREATE FUNCTION f2 () RETURNS VARCHAR(1)
 | ||
| BEGIN
 | ||
| DECLARE rec1 ROW TYPE OF v1;
 | ||
| SELECT z INTO rec1 FROM v1;
 | ||
| RETURN 1;
 | ||
| END|
 | ||
| CREATE FUNCTION f1 () RETURNS VARCHAR(1) RETURN f2() ;
 | ||
| CREATE FUNCTION f3 () RETURNS VARCHAR(1) RETURN f_not_exist();
 | ||
| CREATE VIEW v1 AS SELECT f3() z;
 | ||
| SELECT f1();
 | ||
| ERROR HY000: View 'test.v1' references invalid table(s) or column(s) or function(s) or definer/invoker of view lack rights to use them
 | ||
| # Check that crash doen't happen in case f3 completes with success.
 | ||
| DROP FUNCTION f3;
 | ||
| CREATE FUNCTION f3 () RETURNS VARCHAR(1) RETURN '!';
 | ||
| SELECT f1();
 | ||
| f1()
 | ||
| 1
 | ||
| # Clean up
 | ||
| DROP FUNCTION f1;
 | ||
| DROP FUNCTION f2;
 | ||
| DROP FUNCTION f3;
 | ||
| DROP VIEW v1;
 | ||
| #
 | ||
| # MDEV-33270: Call of SP invoking another SP with a parameter
 | ||
| #             requiring type conversion
 | ||
| #
 | ||
| SET NAMES latin1;
 | ||
| CREATE PROCEDURE p1 (a text) BEGIN SELECT a; END |
 | ||
| CREATE PROCEDURE p2 () CALL p1(concat('x',_utf8'x')) |
 | ||
| CALL p2();
 | ||
| a
 | ||
| xx
 | ||
| CALL p2();
 | ||
| a
 | ||
| xx
 | ||
| DROP PROCEDURE p1;
 | ||
| DROP PROCEDURE p2;
 | ||
| # End of 10.4 tests
 | ||
| #
 | ||
| # MDEV-35910: Pushdown of conditions with local SP variables
 | ||
| #             into materialized derived table
 | ||
| #             Pushdown of conditions with local variables from HAVING
 | ||
| #             into WHERE
 | ||
| #
 | ||
| CREATE TABLE t1(
 | ||
| pk INT PRIMARY KEY AUTO_INCREMENT,
 | ||
| a INT,
 | ||
| b INT
 | ||
| );
 | ||
| INSERT INTO t1(a,b) VALUES (1, 2), (3, 2), (4, 5);
 | ||
| INSERT INTO t1(a,b) VALUES (3, 7), (4, 1), (3, 4);
 | ||
| CREATE PROCEDURE pushdownDerivedSp()
 | ||
| BEGIN
 | ||
| DECLARE localA INT DEFAULT 1;
 | ||
| DECLARE localB INT DEFAULT 2;
 | ||
| SELECT dt.a
 | ||
| FROM (
 | ||
| SELECT t1.a, MIN(t1.b) as minB
 | ||
| FROM t1
 | ||
| GROUP BY t1.a
 | ||
| ) AS dt
 | ||
| WHERE dt.minB = localB AND dt.a = localA + localB;
 | ||
| END$$
 | ||
| CREATE PROCEDURE explainPushdownDerivedSp()
 | ||
| BEGIN
 | ||
| DECLARE localA INT DEFAULT 1;
 | ||
| DECLARE localB INT DEFAULT 2;
 | ||
| EXPLAIN format=json SELECT dt.a
 | ||
| FROM (
 | ||
| SELECT t1.a, MIN(t1.b) as minB
 | ||
| FROM t1
 | ||
| GROUP BY t1.a
 | ||
| ) AS dt
 | ||
| WHERE dt.minB = localB AND dt.a = localA + localB;
 | ||
| END$$
 | ||
| CREATE PROCEDURE pushdownFromHavingSp()
 | ||
| BEGIN
 | ||
| DECLARE localA INT DEFAULT 1;
 | ||
| DECLARE localB INT DEFAULT 2;
 | ||
| SELECT t1.a, SUM(b)
 | ||
| FROM t1
 | ||
| GROUP BY t1.a
 | ||
| HAVING t1.a > localA AND SUM(b) > 10 OR t1.a <= localB AND SUM(b) <= 2;
 | ||
| END$$
 | ||
| CREATE PROCEDURE explainPushdownFromHavingSp()
 | ||
| BEGIN
 | ||
| DECLARE localA INT DEFAULT 1;
 | ||
| DECLARE localB INT DEFAULT 2;
 | ||
| EXPLAIN format=json
 | ||
| SELECT t1.a, SUM(b)
 | ||
| FROM t1
 | ||
| GROUP BY t1.a
 | ||
| HAVING t1.a > localA AND SUM(b) > 10 OR t1.a <= localB AND SUM(b) <= 2;
 | ||
| END$$
 | ||
| CALL pushdownDerivedSp();
 | ||
| a
 | ||
| 3
 | ||
| set statement optimizer_switch='condition_pushdown_for_derived=off'
 | ||
| for CALL pushdownDerivedSp();
 | ||
| a
 | ||
| 3
 | ||
| CALL explainPushdownDerivedSp();
 | ||
| EXPLAIN
 | ||
| {
 | ||
|   "query_block": {
 | ||
|     "select_id": 1,
 | ||
|     "cost": 0.010268108,
 | ||
|     "nested_loop": [
 | ||
|       {
 | ||
|         "table": {
 | ||
|           "table_name": "<derived2>",
 | ||
|           "access_type": "ALL",
 | ||
|           "loops": 1,
 | ||
|           "rows": 6,
 | ||
|           "cost": 0.010268108,
 | ||
|           "filtered": 100,
 | ||
|           "attached_condition": "dt.minB = <cache>(localB@1) and dt.a = <cache>(localA@0 + localB@1)",
 | ||
|           "materialized": {
 | ||
|             "query_block": {
 | ||
|               "select_id": 2,
 | ||
|               "cost": 0.014784479,
 | ||
|               "having_condition": "minB = <cache>(localB@1)",
 | ||
|               "nested_loop": [
 | ||
|                 {
 | ||
|                   "table": {
 | ||
|                     "table_name": "t1",
 | ||
|                     "access_type": "ALL",
 | ||
|                     "loops": 1,
 | ||
|                     "rows": 6,
 | ||
|                     "cost": 0.01097403,
 | ||
|                     "filtered": 100,
 | ||
|                     "attached_condition": "t1.a = <cache>(localA@0 + localB@1)"
 | ||
|                   }
 | ||
|                 }
 | ||
|               ]
 | ||
|             }
 | ||
|           }
 | ||
|         }
 | ||
|       }
 | ||
|     ]
 | ||
|   }
 | ||
| }
 | ||
| set statement optimizer_switch='condition_pushdown_for_derived=off' for
 | ||
| CALL explainPushdownDerivedSp();
 | ||
| EXPLAIN
 | ||
| {
 | ||
|   "query_block": {
 | ||
|     "select_id": 1,
 | ||
|     "cost": 0.010268108,
 | ||
|     "nested_loop": [
 | ||
|       {
 | ||
|         "table": {
 | ||
|           "table_name": "<derived2>",
 | ||
|           "access_type": "ALL",
 | ||
|           "loops": 1,
 | ||
|           "rows": 6,
 | ||
|           "cost": 0.010268108,
 | ||
|           "filtered": 100,
 | ||
|           "attached_condition": "dt.minB = <cache>(localB@1) and dt.a = <cache>(localA@0 + localB@1)",
 | ||
|           "materialized": {
 | ||
|             "query_block": {
 | ||
|               "select_id": 2,
 | ||
|               "cost": 0.014784479,
 | ||
|               "filesort": {
 | ||
|                 "sort_key": "t1.a",
 | ||
|                 "temporary_table": {
 | ||
|                   "nested_loop": [
 | ||
|                     {
 | ||
|                       "table": {
 | ||
|                         "table_name": "t1",
 | ||
|                         "access_type": "ALL",
 | ||
|                         "loops": 1,
 | ||
|                         "rows": 6,
 | ||
|                         "cost": 0.01097403,
 | ||
|                         "filtered": 100
 | ||
|                       }
 | ||
|                     }
 | ||
|                   ]
 | ||
|                 }
 | ||
|               }
 | ||
|             }
 | ||
|           }
 | ||
|         }
 | ||
|       }
 | ||
|     ]
 | ||
|   }
 | ||
| }
 | ||
| CALL pushdownFromHavingSp();
 | ||
| a	SUM(b)
 | ||
| 1	2
 | ||
| 3	13
 | ||
| set statement optimizer_switch='condition_pushdown_from_having=off' for
 | ||
| CALL pushdownFromHavingSp();
 | ||
| a	SUM(b)
 | ||
| 1	2
 | ||
| 3	13
 | ||
| CALL explainPushdownFromHavingSp();
 | ||
| EXPLAIN
 | ||
| {
 | ||
|   "query_block": {
 | ||
|     "select_id": 1,
 | ||
|     "cost": 0.014784479,
 | ||
|     "having_condition": "t1.a > <cache>(localA@0) and sum(t1.b) > 10 or t1.a <= <cache>(localB@1) and sum(t1.b) <= 2",
 | ||
|     "filesort": {
 | ||
|       "sort_key": "t1.a",
 | ||
|       "temporary_table": {
 | ||
|         "nested_loop": [
 | ||
|           {
 | ||
|             "table": {
 | ||
|               "table_name": "t1",
 | ||
|               "access_type": "ALL",
 | ||
|               "loops": 1,
 | ||
|               "rows": 6,
 | ||
|               "cost": 0.01097403,
 | ||
|               "filtered": 100,
 | ||
|               "attached_condition": "t1.a > <cache>(localA@0) or t1.a <= <cache>(localB@1)"
 | ||
|             }
 | ||
|           }
 | ||
|         ]
 | ||
|       }
 | ||
|     }
 | ||
|   }
 | ||
| }
 | ||
| set statement optimizer_switch='condition_pushdown_from_having=off' for
 | ||
| CALL explainPushdownFromHavingSp();
 | ||
| EXPLAIN
 | ||
| {
 | ||
|   "query_block": {
 | ||
|     "select_id": 1,
 | ||
|     "cost": 0.014784479,
 | ||
|     "having_condition": "t1.a > <cache>(localA@0) and sum(t1.b) > 10 or t1.a <= <cache>(localB@1) and sum(t1.b) <= 2",
 | ||
|     "filesort": {
 | ||
|       "sort_key": "t1.a",
 | ||
|       "temporary_table": {
 | ||
|         "nested_loop": [
 | ||
|           {
 | ||
|             "table": {
 | ||
|               "table_name": "t1",
 | ||
|               "access_type": "ALL",
 | ||
|               "loops": 1,
 | ||
|               "rows": 6,
 | ||
|               "cost": 0.01097403,
 | ||
|               "filtered": 100
 | ||
|             }
 | ||
|           }
 | ||
|         ]
 | ||
|       }
 | ||
|     }
 | ||
|   }
 | ||
| }
 | ||
| DROP PROCEDURE pushdownDerivedSp;
 | ||
| DROP PROCEDURE explainPushdownDerivedSp;
 | ||
| DROP PROCEDURE pushdownFromHavingSp;
 | ||
| DROP PROCEDURE explainPushdownFromHavingSp;
 | ||
| DROP TABLE t1;
 | ||
| # End of 10.5 tests
 | ||
| #
 | ||
| # MDEV-29129: Performance regression starting in 10.6: unlimited "select order by limit"
 | ||
| #
 | ||
| CREATE TABLE t1 (
 | ||
| lookupId int primary key,
 | ||
| value varchar(255)
 | ||
| );
 | ||
| insert into t1 select seq, seq from seq_1_to_100;
 | ||
| # Note: the function is intentionally NOT declared as DETERMINISTIC
 | ||
| CREATE FUNCTION f1(LOOKUPID_IN INT) RETURNS varchar(255) CHARSET utf8
 | ||
| BEGIN
 | ||
| DECLARE LOOKUP_VALUE VARCHAR(255);
 | ||
| SET LOOKUP_VALUE = (SELECT value FROM t1 WHERE lookupId = LOOKUPID_IN);
 | ||
| set @counter=@counter+1;
 | ||
| RETURN LOOKUP_VALUE;
 | ||
| END; 
 | ||
| //
 | ||
| create table t2 (
 | ||
| col1 int,
 | ||
| col2 int
 | ||
| );
 | ||
| insert into t2 select mod(seq,100), seq from seq_1_to_1000;
 | ||
| explain 
 | ||
| select f1(col1) from t2 order by col2 desc limit 5;
 | ||
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | ||
| 1	SIMPLE	t2	ALL	NULL	NULL	NULL	NULL	1000	Using filesort
 | ||
| set @counter=0;
 | ||
| select f1(col1) from t2 order by col2 desc limit 5;
 | ||
| f1(col1)
 | ||
| NULL
 | ||
| 99
 | ||
| 98
 | ||
| 97
 | ||
| 96
 | ||
| # Must show 5, not 1000:
 | ||
| select @counter;
 | ||
| @counter
 | ||
| 5
 | ||
| drop function f1;
 | ||
| drop table t1,t2;
 | ||
| # 
 | ||
| # MDEV-31877: ASAN errors in Exec_time_tracker::get_cycles with innodb slow log verbosity
 | ||
| # 
 | ||
| CREATE TABLE t1 (a INT, b INT);
 | ||
| INSERT INTO t1 VALUES (1,2);
 | ||
| SET @tmp=@@log_slow_verbosity;
 | ||
| SET SESSION log_slow_verbosity= 'innodb';
 | ||
| BEGIN NOT ATOMIC DECLARE r ROW TYPE OF t1 DEFAULT (SELECT * FROM t1); SELECT r.a; END $
 | ||
| r.a
 | ||
| 1
 | ||
| SET SESSION log_slow_verbosity= @tmp;
 | ||
| # 
 | ||
| # MDEV-31616 Problems with a stored function EMPTY() on upgrade to 10.6.
 | ||
| # 
 | ||
| CREATE OR REPLACE FUNCTION empty(a VARCHAR(128)) RETURNS int RETURN LENGTH(a)=0;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'empty' has the same name as a native function
 | ||
| SELECT empty('1');
 | ||
| empty('1')
 | ||
| 0
 | ||
| Warnings:
 | ||
| Note	1585	This function 'empty' has the same name as a native function
 | ||
| DROP FUNCTION empty;
 | ||
| CREATE OR REPLACE FUNCTION json_table(a VARCHAR(128)) RETURNS int RETURN LENGTH(a)=0;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'json_table' has the same name as a native function
 | ||
| SELECT json_table('1');
 | ||
| json_table('1')
 | ||
| 0
 | ||
| Warnings:
 | ||
| Note	1585	This function 'json_table' has the same name as a native function
 | ||
| DROP FUNCTION json_table;
 | ||
| CREATE OR REPLACE FUNCTION nested(a VARCHAR(128)) RETURNS int RETURN LENGTH(a)=0;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'nested' has the same name as a native function
 | ||
| SELECT nested('1');
 | ||
| nested('1')
 | ||
| 0
 | ||
| Warnings:
 | ||
| Note	1585	This function 'nested' has the same name as a native function
 | ||
| DROP FUNCTION nested;
 | ||
| CREATE OR REPLACE FUNCTION ordinality(a VARCHAR(128)) RETURNS int RETURN LENGTH(a)=0;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'ordinality' has the same name as a native function
 | ||
| SELECT ordinality('1');
 | ||
| ordinality('1')
 | ||
| 0
 | ||
| Warnings:
 | ||
| Note	1585	This function 'ordinality' has the same name as a native function
 | ||
| DROP FUNCTION ordinality;
 | ||
| CREATE OR REPLACE FUNCTION path(a VARCHAR(128)) RETURNS int RETURN LENGTH(a)=0;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'path' has the same name as a native function
 | ||
| SELECT path('1');
 | ||
| path('1')
 | ||
| 0
 | ||
| Warnings:
 | ||
| Note	1585	This function 'path' has the same name as a native function
 | ||
| DROP FUNCTION path;
 | ||
| CREATE OR REPLACE FUNCTION fast(a VARCHAR(128)) RETURNS int RETURN LENGTH(a)=0;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'fast' has the same name as a native function
 | ||
| SELECT fast('1');
 | ||
| fast('1')
 | ||
| 0
 | ||
| Warnings:
 | ||
| Note	1585	This function 'fast' has the same name as a native function
 | ||
| DROP FUNCTION fast;
 | ||
| CREATE OR REPLACE FUNCTION relay(a VARCHAR(128)) RETURNS int RETURN LENGTH(a)=0;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'relay' has the same name as a native function
 | ||
| SELECT relay('1');
 | ||
| relay('1')
 | ||
| 0
 | ||
| Warnings:
 | ||
| Note	1585	This function 'relay' has the same name as a native function
 | ||
| DROP FUNCTION relay;
 | ||
| CREATE OR REPLACE FUNCTION database() RETURNS int RETURN 333;
 | ||
| Warnings:
 | ||
| Note	1585	This function 'database' has the same name as a native function
 | ||
| SELECT database();
 | ||
| database()
 | ||
| test
 | ||
| DROP FUNCTION database;
 | ||
| DROP TABLE t1;
 | ||
| # End of 10.6 tests
 | ||
| #
 | ||
| # MDEV-28129: MariaDB UAF issue at lex_end_nops(LEX*)
 | ||
| #
 | ||
| CREATE PROCEDURE sp() SELECT 1 INTO @;
 | ||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '' at line 1
 | ||
| CREATE PROCEDURE sp() SET @=1;
 | ||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '=1' at line 1
 | ||
| CREATE PROCEDURE sp() SELECT @;
 | ||
| ERROR 42000: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '' at line 1
 | ||
| # End of 10.7 tests
 | ||
| #
 | ||
| # MDEV-35437 Suppress "This function has the same name" warnings in I_S queries
 | ||
| #
 | ||
| CREATE FUNCTION upper() RETURNS TEXT RETURN 'upper';
 | ||
| Warnings:
 | ||
| Note	1585	This function 'upper' has the same name as a native function
 | ||
| SELECT test.upper();
 | ||
| test.upper()
 | ||
| upper
 | ||
| Warnings:
 | ||
| Note	1585	This function 'upper' has the same name as a native function
 | ||
| SELECT ROUTINE_NAME FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA='test' AND ROUTINE_NAME='upper';
 | ||
| ROUTINE_NAME
 | ||
| upper
 | ||
| SELECT SPECIFIC_NAME FROM INFORMATION_SCHEMA.PARAMETERS WHERE SPECIFIC_SCHEMA='test' AND SPECIFIC_NAME='upper';
 | ||
| SPECIFIC_NAME
 | ||
| upper
 | ||
| DROP FUNCTION upper;
 | ||
| # End of 11.8 tests
 |