mirror of
https://github.com/MariaDB/server.git
synced 2025-01-25 00:04:33 +01:00
f65cb96b60
into pilot.blaudden:/home/msvensson/mysql/mysql-5.1-maint client/client_priv.h: Auto merged mysql-test/mysql-test-run.pl: Auto merged mysql-test/r/create.result: Auto merged mysql-test/r/mysqldump.result: Auto merged mysql-test/r/rpl_deadlock_innodb.result: Auto merged mysql-test/r/rpl_flushlog_loop.result: Auto merged mysql-test/r/rpl_known_bugs_detection.result: Auto merged mysql-test/r/rpl_ndb_basic.result: Auto merged mysql-test/r/rpl_ndb_extraCol.result: Auto merged mysql-test/r/rpl_ndb_sync.result: Auto merged mysql-test/r/rpl_rbr_to_sbr.result: Auto merged mysql-test/r/rpl_row_inexist_tbl.result: Auto merged mysql-test/r/rpl_row_max_relay_size.result: Auto merged mysql-test/r/rpl_row_tabledefs_2myisam.result: Auto merged mysql-test/r/rpl_row_tabledefs_3innodb.result: Auto merged mysql-test/r/rpl_stm_max_relay_size.result: Auto merged mysql-test/r/rpl_stm_until.result: Auto merged mysql-test/r/sp-code.result: Auto merged mysql-test/r/type_datetime.result: Auto merged mysql-test/t/mysqlbinlog.test: Auto merged sql/field.cc: Auto merged sql/field.h: Auto merged sql/item.h: Auto merged sql/item_func.cc: Auto merged sql/item_strfunc.cc: Auto merged sql/item_sum.cc: Auto merged sql/lex.h: Auto merged sql/log.cc: Auto merged sql/log_event.cc: Auto merged sql/slave.cc: Auto merged sql/sql_show.cc: Auto merged sql/sql_yacc.yy: Auto merged mysql-test/r/gis.result: Merge 5.0->5.1 mysql-test/r/rpl_000015.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_change_master.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_loaddata.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_log_pos.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_ndb_log.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_rotate_logs.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_row_log.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_row_log_innodb.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_row_reset_slave.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_row_until.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_server_id1.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_server_id2.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_stm_log.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/r/rpl_stm_reset_slave.result: Merge after adding new column to SHOW SLAVE STATUS mysql-test/t/gis.test: Merge 5.0->5.1
640 lines
14 KiB
Text
640 lines
14 KiB
Text
drop procedure if exists empty;
|
|
drop procedure if exists code_sample;
|
|
create procedure empty()
|
|
begin
|
|
end;
|
|
show procedure code empty;
|
|
Pos Instruction
|
|
drop procedure empty;
|
|
create function almost_empty()
|
|
returns int
|
|
return 0;
|
|
show function code almost_empty;
|
|
Pos Instruction
|
|
0 freturn 3 0
|
|
drop function almost_empty;
|
|
create procedure code_sample(x int, out err int, out nulls int)
|
|
begin
|
|
declare count int default 0;
|
|
set nulls = 0;
|
|
begin
|
|
declare c cursor for select name from t1;
|
|
declare exit handler for not found close c;
|
|
open c;
|
|
loop
|
|
begin
|
|
declare n varchar(20);
|
|
declare continue handler for sqlexception set err=1;
|
|
fetch c into n;
|
|
if isnull(n) then
|
|
set nulls = nulls + 1;
|
|
else
|
|
set count = count + 1;
|
|
update t2 set idx = count where name=n;
|
|
end if;
|
|
end;
|
|
end loop;
|
|
end;
|
|
select t.name, t.idx from t2 t order by idx asc;
|
|
end//
|
|
show procedure code code_sample;
|
|
Pos Instruction
|
|
0 set count@3 0
|
|
1 set nulls@2 0
|
|
2 cpush c@0
|
|
3 hpush_jump 6 4 EXIT
|
|
4 cclose c@0
|
|
5 hreturn 0 19
|
|
6 copen c@0
|
|
7 set n@4 NULL
|
|
8 hpush_jump 11 5 CONTINUE
|
|
9 set err@1 1
|
|
10 hreturn 5
|
|
11 cfetch c@0 n@4
|
|
12 jump_if_not 15(17) isnull(n@4)
|
|
13 set nulls@2 (nulls@2 + 1)
|
|
14 jump 17
|
|
15 set count@3 (count@3 + 1)
|
|
16 stmt 4 "update t2 set idx = count where name=n"
|
|
17 hpop 1
|
|
18 jump 7
|
|
19 hpop 1
|
|
20 cpop 1
|
|
21 stmt 0 "select t.name, t.idx from t2 t order ..."
|
|
drop procedure code_sample;
|
|
drop procedure if exists sudoku_solve;
|
|
create procedure sudoku_solve(p_naive boolean, p_all boolean)
|
|
deterministic
|
|
modifies sql data
|
|
begin
|
|
drop temporary table if exists sudoku_work, sudoku_schedule;
|
|
create temporary table sudoku_work
|
|
(
|
|
row smallint not null,
|
|
col smallint not null,
|
|
dig smallint not null,
|
|
cnt smallint,
|
|
key using btree (cnt),
|
|
key using btree (row),
|
|
key using btree (col),
|
|
unique key using hash (row,col)
|
|
);
|
|
create temporary table sudoku_schedule
|
|
(
|
|
idx int not null auto_increment primary key,
|
|
row smallint not null,
|
|
col smallint not null
|
|
);
|
|
call sudoku_init();
|
|
if p_naive then
|
|
update sudoku_work set cnt = 0 where dig = 0;
|
|
else
|
|
call sudoku_count();
|
|
end if;
|
|
insert into sudoku_schedule (row,col)
|
|
select row,col from sudoku_work where cnt is not null order by cnt desc;
|
|
begin
|
|
declare v_scounter bigint default 0;
|
|
declare v_i smallint default 1;
|
|
declare v_dig smallint;
|
|
declare v_schedmax smallint;
|
|
select count(*) into v_schedmax from sudoku_schedule;
|
|
more:
|
|
loop
|
|
begin
|
|
declare v_tcounter bigint default 0;
|
|
sched:
|
|
while v_i <= v_schedmax do
|
|
begin
|
|
declare v_row, v_col smallint;
|
|
select row,col into v_row,v_col from sudoku_schedule where v_i = idx;
|
|
select dig into v_dig from sudoku_work
|
|
where v_row = row and v_col = col;
|
|
case v_dig
|
|
when 0 then
|
|
set v_dig = 1;
|
|
update sudoku_work set dig = 1
|
|
where v_row = row and v_col = col;
|
|
when 9 then
|
|
if v_i > 0 then
|
|
update sudoku_work set dig = 0
|
|
where v_row = row and v_col = col;
|
|
set v_i = v_i - 1;
|
|
iterate sched;
|
|
else
|
|
select v_scounter as 'Solutions';
|
|
leave more;
|
|
end if;
|
|
else
|
|
set v_dig = v_dig + 1;
|
|
update sudoku_work set dig = v_dig
|
|
where v_row = row and v_col = col;
|
|
end case;
|
|
set v_tcounter = v_tcounter + 1;
|
|
if not sudoku_digit_ok(v_row, v_col, v_dig) then
|
|
iterate sched;
|
|
end if;
|
|
set v_i = v_i + 1;
|
|
end;
|
|
end while sched;
|
|
select dig from sudoku_work;
|
|
select v_tcounter as 'Tests';
|
|
set v_scounter = v_scounter + 1;
|
|
if p_all and v_i > 0 then
|
|
set v_i = v_i - 1;
|
|
else
|
|
leave more;
|
|
end if;
|
|
end;
|
|
end loop more;
|
|
end;
|
|
drop temporary table sudoku_work, sudoku_schedule;
|
|
end//
|
|
show procedure code sudoku_solve;
|
|
Pos Instruction
|
|
0 stmt 9 "drop temporary table if exists sudoku..."
|
|
1 stmt 1 "create temporary table sudoku_work ( ..."
|
|
2 stmt 1 "create temporary table sudoku_schedul..."
|
|
3 stmt 95 "call sudoku_init()"
|
|
4 jump_if_not 7(8) p_naive@0
|
|
5 stmt 4 "update sudoku_work set cnt = 0 where ..."
|
|
6 jump 8
|
|
7 stmt 95 "call sudoku_count()"
|
|
8 stmt 6 "insert into sudoku_schedule (row,col)..."
|
|
9 set v_scounter@2 0
|
|
10 set v_i@3 1
|
|
11 set v_dig@4 NULL
|
|
12 set v_schedmax@5 NULL
|
|
13 stmt 0 "select count(*) into v_schedmax from ..."
|
|
14 set v_tcounter@6 0
|
|
15 jump_if_not 39(39) (v_i@3 <= v_schedmax@5)
|
|
16 set v_row@7 NULL
|
|
17 set v_col@8 NULL
|
|
18 stmt 0 "select row,col into v_row,v_col from ..."
|
|
19 stmt 0 "select dig into v_dig from sudoku_wor..."
|
|
20 set_case_expr (34) 0 v_dig@4
|
|
21 jump_if_not 25(34) (case_expr@0 = 0)
|
|
22 set v_dig@4 1
|
|
23 stmt 4 "update sudoku_work set dig = 1 where ..."
|
|
24 jump 34
|
|
25 jump_if_not 32(34) (case_expr@0 = 9)
|
|
26 jump_if_not 30(34) (v_i@3 > 0)
|
|
27 stmt 4 "update sudoku_work set dig = 0 where ..."
|
|
28 set v_i@3 (v_i@3 - 1)
|
|
29 jump 15
|
|
30 stmt 0 "select v_scounter as 'Solutions'"
|
|
31 jump 45
|
|
32 set v_dig@4 (v_dig@4 + 1)
|
|
33 stmt 4 "update sudoku_work set dig = v_dig wh..."
|
|
34 set v_tcounter@6 (v_tcounter@6 + 1)
|
|
35 jump_if_not 37(37) (not(`sudoku_digit_ok`(v_row@7,v_col@8,v_dig@4)))
|
|
36 jump 15
|
|
37 set v_i@3 (v_i@3 + 1)
|
|
38 jump 15
|
|
39 stmt 0 "select dig from sudoku_work"
|
|
40 stmt 0 "select v_tcounter as 'Tests'"
|
|
41 set v_scounter@2 (v_scounter@2 + 1)
|
|
42 jump_if_not 45(14) (p_all@1 and (v_i@3 > 0))
|
|
43 set v_i@3 (v_i@3 - 1)
|
|
44 jump 14
|
|
45 stmt 9 "drop temporary table sudoku_work, sud..."
|
|
drop procedure sudoku_solve;
|
|
DROP PROCEDURE IF EXISTS proc_19194_simple;
|
|
DROP PROCEDURE IF EXISTS proc_19194_searched;
|
|
DROP PROCEDURE IF EXISTS proc_19194_nested_1;
|
|
DROP PROCEDURE IF EXISTS proc_19194_nested_2;
|
|
DROP PROCEDURE IF EXISTS proc_19194_nested_3;
|
|
DROP PROCEDURE IF EXISTS proc_19194_nested_4;
|
|
CREATE PROCEDURE proc_19194_simple(i int)
|
|
BEGIN
|
|
DECLARE str CHAR(10);
|
|
CASE i
|
|
WHEN 1 THEN SET str="1";
|
|
WHEN 2 THEN SET str="2";
|
|
WHEN 3 THEN SET str="3";
|
|
ELSE SET str="unknown";
|
|
END CASE;
|
|
SELECT str;
|
|
END|
|
|
CREATE PROCEDURE proc_19194_searched(i int)
|
|
BEGIN
|
|
DECLARE str CHAR(10);
|
|
CASE
|
|
WHEN i=1 THEN SET str="1";
|
|
WHEN i=2 THEN SET str="2";
|
|
WHEN i=3 THEN SET str="3";
|
|
ELSE SET str="unknown";
|
|
END CASE;
|
|
SELECT str;
|
|
END|
|
|
CREATE PROCEDURE proc_19194_nested_1(i int, j int)
|
|
BEGIN
|
|
DECLARE str_i CHAR(10);
|
|
DECLARE str_j CHAR(10);
|
|
CASE i
|
|
WHEN 10 THEN SET str_i="10";
|
|
WHEN 20 THEN
|
|
BEGIN
|
|
set str_i="20";
|
|
CASE
|
|
WHEN j=1 THEN SET str_j="1";
|
|
WHEN j=2 THEN SET str_j="2";
|
|
WHEN j=3 THEN SET str_j="3";
|
|
ELSE SET str_j="unknown";
|
|
END CASE;
|
|
select "i was 20";
|
|
END;
|
|
WHEN 30 THEN SET str_i="30";
|
|
WHEN 40 THEN SET str_i="40";
|
|
ELSE SET str_i="unknown";
|
|
END CASE;
|
|
SELECT str_i, str_j;
|
|
END|
|
|
CREATE PROCEDURE proc_19194_nested_2(i int, j int)
|
|
BEGIN
|
|
DECLARE str_i CHAR(10);
|
|
DECLARE str_j CHAR(10);
|
|
CASE
|
|
WHEN i=10 THEN SET str_i="10";
|
|
WHEN i=20 THEN
|
|
BEGIN
|
|
set str_i="20";
|
|
CASE j
|
|
WHEN 1 THEN SET str_j="1";
|
|
WHEN 2 THEN SET str_j="2";
|
|
WHEN 3 THEN SET str_j="3";
|
|
ELSE SET str_j="unknown";
|
|
END CASE;
|
|
select "i was 20";
|
|
END;
|
|
WHEN i=30 THEN SET str_i="30";
|
|
WHEN i=40 THEN SET str_i="40";
|
|
ELSE SET str_i="unknown";
|
|
END CASE;
|
|
SELECT str_i, str_j;
|
|
END|
|
|
CREATE PROCEDURE proc_19194_nested_3(i int, j int)
|
|
BEGIN
|
|
DECLARE str_i CHAR(10);
|
|
DECLARE str_j CHAR(10);
|
|
CASE i
|
|
WHEN 10 THEN SET str_i="10";
|
|
WHEN 20 THEN
|
|
BEGIN
|
|
set str_i="20";
|
|
CASE j
|
|
WHEN 1 THEN SET str_j="1";
|
|
WHEN 2 THEN SET str_j="2";
|
|
WHEN 3 THEN SET str_j="3";
|
|
ELSE SET str_j="unknown";
|
|
END CASE;
|
|
select "i was 20";
|
|
END;
|
|
WHEN 30 THEN SET str_i="30";
|
|
WHEN 40 THEN SET str_i="40";
|
|
ELSE SET str_i="unknown";
|
|
END CASE;
|
|
SELECT str_i, str_j;
|
|
END|
|
|
CREATE PROCEDURE proc_19194_nested_4(i int, j int)
|
|
BEGIN
|
|
DECLARE str_i CHAR(10);
|
|
DECLARE str_j CHAR(10);
|
|
CASE
|
|
WHEN i=10 THEN SET str_i="10";
|
|
WHEN i=20 THEN
|
|
BEGIN
|
|
set str_i="20";
|
|
CASE
|
|
WHEN j=1 THEN SET str_j="1";
|
|
WHEN j=2 THEN SET str_j="2";
|
|
WHEN j=3 THEN SET str_j="3";
|
|
ELSE SET str_j="unknown";
|
|
END CASE;
|
|
select "i was 20";
|
|
END;
|
|
WHEN i=30 THEN SET str_i="30";
|
|
WHEN i=40 THEN SET str_i="40";
|
|
ELSE SET str_i="unknown";
|
|
END CASE;
|
|
SELECT str_i, str_j;
|
|
END|
|
|
SHOW PROCEDURE CODE proc_19194_simple;
|
|
Pos Instruction
|
|
0 set str@1 NULL
|
|
1 set_case_expr (12) 0 i@0
|
|
2 jump_if_not 5(12) (case_expr@0 = 1)
|
|
3 set str@1 _latin1'1'
|
|
4 jump 12
|
|
5 jump_if_not 8(12) (case_expr@0 = 2)
|
|
6 set str@1 _latin1'2'
|
|
7 jump 12
|
|
8 jump_if_not 11(12) (case_expr@0 = 3)
|
|
9 set str@1 _latin1'3'
|
|
10 jump 12
|
|
11 set str@1 _latin1'unknown'
|
|
12 stmt 0 "SELECT str"
|
|
SHOW PROCEDURE CODE proc_19194_searched;
|
|
Pos Instruction
|
|
0 set str@1 NULL
|
|
1 jump_if_not 4(11) (i@0 = 1)
|
|
2 set str@1 _latin1'1'
|
|
3 jump 11
|
|
4 jump_if_not 7(11) (i@0 = 2)
|
|
5 set str@1 _latin1'2'
|
|
6 jump 11
|
|
7 jump_if_not 10(11) (i@0 = 3)
|
|
8 set str@1 _latin1'3'
|
|
9 jump 11
|
|
10 set str@1 _latin1'unknown'
|
|
11 stmt 0 "SELECT str"
|
|
SHOW PROCEDURE CODE proc_19194_nested_1;
|
|
Pos Instruction
|
|
0 set str_i@2 NULL
|
|
1 set str_j@3 NULL
|
|
2 set_case_expr (27) 0 i@0
|
|
3 jump_if_not 6(27) (case_expr@0 = 10)
|
|
4 set str_i@2 _latin1'10'
|
|
5 jump 27
|
|
6 jump_if_not 20(27) (case_expr@0 = 20)
|
|
7 set str_i@2 _latin1'20'
|
|
8 jump_if_not 11(18) (j@1 = 1)
|
|
9 set str_j@3 _latin1'1'
|
|
10 jump 18
|
|
11 jump_if_not 14(18) (j@1 = 2)
|
|
12 set str_j@3 _latin1'2'
|
|
13 jump 18
|
|
14 jump_if_not 17(18) (j@1 = 3)
|
|
15 set str_j@3 _latin1'3'
|
|
16 jump 18
|
|
17 set str_j@3 _latin1'unknown'
|
|
18 stmt 0 "select "i was 20""
|
|
19 jump 27
|
|
20 jump_if_not 23(27) (case_expr@0 = 30)
|
|
21 set str_i@2 _latin1'30'
|
|
22 jump 27
|
|
23 jump_if_not 26(27) (case_expr@0 = 40)
|
|
24 set str_i@2 _latin1'40'
|
|
25 jump 27
|
|
26 set str_i@2 _latin1'unknown'
|
|
27 stmt 0 "SELECT str_i, str_j"
|
|
SHOW PROCEDURE CODE proc_19194_nested_2;
|
|
Pos Instruction
|
|
0 set str_i@2 NULL
|
|
1 set str_j@3 NULL
|
|
2 jump_if_not 5(27) (i@0 = 10)
|
|
3 set str_i@2 _latin1'10'
|
|
4 jump 27
|
|
5 jump_if_not 20(27) (i@0 = 20)
|
|
6 set str_i@2 _latin1'20'
|
|
7 set_case_expr (18) 0 j@1
|
|
8 jump_if_not 11(18) (case_expr@0 = 1)
|
|
9 set str_j@3 _latin1'1'
|
|
10 jump 18
|
|
11 jump_if_not 14(18) (case_expr@0 = 2)
|
|
12 set str_j@3 _latin1'2'
|
|
13 jump 18
|
|
14 jump_if_not 17(18) (case_expr@0 = 3)
|
|
15 set str_j@3 _latin1'3'
|
|
16 jump 18
|
|
17 set str_j@3 _latin1'unknown'
|
|
18 stmt 0 "select "i was 20""
|
|
19 jump 27
|
|
20 jump_if_not 23(27) (i@0 = 30)
|
|
21 set str_i@2 _latin1'30'
|
|
22 jump 27
|
|
23 jump_if_not 26(27) (i@0 = 40)
|
|
24 set str_i@2 _latin1'40'
|
|
25 jump 27
|
|
26 set str_i@2 _latin1'unknown'
|
|
27 stmt 0 "SELECT str_i, str_j"
|
|
SHOW PROCEDURE CODE proc_19194_nested_3;
|
|
Pos Instruction
|
|
0 set str_i@2 NULL
|
|
1 set str_j@3 NULL
|
|
2 set_case_expr (28) 0 i@0
|
|
3 jump_if_not 6(28) (case_expr@0 = 10)
|
|
4 set str_i@2 _latin1'10'
|
|
5 jump 28
|
|
6 jump_if_not 21(28) (case_expr@0 = 20)
|
|
7 set str_i@2 _latin1'20'
|
|
8 set_case_expr (19) 1 j@1
|
|
9 jump_if_not 12(19) (case_expr@1 = 1)
|
|
10 set str_j@3 _latin1'1'
|
|
11 jump 19
|
|
12 jump_if_not 15(19) (case_expr@1 = 2)
|
|
13 set str_j@3 _latin1'2'
|
|
14 jump 19
|
|
15 jump_if_not 18(19) (case_expr@1 = 3)
|
|
16 set str_j@3 _latin1'3'
|
|
17 jump 19
|
|
18 set str_j@3 _latin1'unknown'
|
|
19 stmt 0 "select "i was 20""
|
|
20 jump 28
|
|
21 jump_if_not 24(28) (case_expr@0 = 30)
|
|
22 set str_i@2 _latin1'30'
|
|
23 jump 28
|
|
24 jump_if_not 27(28) (case_expr@0 = 40)
|
|
25 set str_i@2 _latin1'40'
|
|
26 jump 28
|
|
27 set str_i@2 _latin1'unknown'
|
|
28 stmt 0 "SELECT str_i, str_j"
|
|
SHOW PROCEDURE CODE proc_19194_nested_4;
|
|
Pos Instruction
|
|
0 set str_i@2 NULL
|
|
1 set str_j@3 NULL
|
|
2 jump_if_not 5(26) (i@0 = 10)
|
|
3 set str_i@2 _latin1'10'
|
|
4 jump 26
|
|
5 jump_if_not 19(26) (i@0 = 20)
|
|
6 set str_i@2 _latin1'20'
|
|
7 jump_if_not 10(17) (j@1 = 1)
|
|
8 set str_j@3 _latin1'1'
|
|
9 jump 17
|
|
10 jump_if_not 13(17) (j@1 = 2)
|
|
11 set str_j@3 _latin1'2'
|
|
12 jump 17
|
|
13 jump_if_not 16(17) (j@1 = 3)
|
|
14 set str_j@3 _latin1'3'
|
|
15 jump 17
|
|
16 set str_j@3 _latin1'unknown'
|
|
17 stmt 0 "select "i was 20""
|
|
18 jump 26
|
|
19 jump_if_not 22(26) (i@0 = 30)
|
|
20 set str_i@2 _latin1'30'
|
|
21 jump 26
|
|
22 jump_if_not 25(26) (i@0 = 40)
|
|
23 set str_i@2 _latin1'40'
|
|
24 jump 26
|
|
25 set str_i@2 _latin1'unknown'
|
|
26 stmt 0 "SELECT str_i, str_j"
|
|
CALL proc_19194_nested_1(10, 1);
|
|
str_i str_j
|
|
10 NULL
|
|
CALL proc_19194_nested_1(25, 1);
|
|
str_i str_j
|
|
unknown NULL
|
|
CALL proc_19194_nested_1(20, 1);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 1
|
|
CALL proc_19194_nested_1(20, 2);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 2
|
|
CALL proc_19194_nested_1(20, 3);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 3
|
|
CALL proc_19194_nested_1(20, 4);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 unknown
|
|
CALL proc_19194_nested_1(30, 1);
|
|
str_i str_j
|
|
30 NULL
|
|
CALL proc_19194_nested_1(40, 1);
|
|
str_i str_j
|
|
40 NULL
|
|
CALL proc_19194_nested_1(0, 0);
|
|
str_i str_j
|
|
unknown NULL
|
|
CALL proc_19194_nested_2(10, 1);
|
|
str_i str_j
|
|
10 NULL
|
|
CALL proc_19194_nested_2(25, 1);
|
|
str_i str_j
|
|
unknown NULL
|
|
CALL proc_19194_nested_2(20, 1);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 1
|
|
CALL proc_19194_nested_2(20, 2);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 2
|
|
CALL proc_19194_nested_2(20, 3);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 3
|
|
CALL proc_19194_nested_2(20, 4);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 unknown
|
|
CALL proc_19194_nested_2(30, 1);
|
|
str_i str_j
|
|
30 NULL
|
|
CALL proc_19194_nested_2(40, 1);
|
|
str_i str_j
|
|
40 NULL
|
|
CALL proc_19194_nested_2(0, 0);
|
|
str_i str_j
|
|
unknown NULL
|
|
CALL proc_19194_nested_3(10, 1);
|
|
str_i str_j
|
|
10 NULL
|
|
CALL proc_19194_nested_3(25, 1);
|
|
str_i str_j
|
|
unknown NULL
|
|
CALL proc_19194_nested_3(20, 1);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 1
|
|
CALL proc_19194_nested_3(20, 2);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 2
|
|
CALL proc_19194_nested_3(20, 3);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 3
|
|
CALL proc_19194_nested_3(20, 4);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 unknown
|
|
CALL proc_19194_nested_3(30, 1);
|
|
str_i str_j
|
|
30 NULL
|
|
CALL proc_19194_nested_3(40, 1);
|
|
str_i str_j
|
|
40 NULL
|
|
CALL proc_19194_nested_3(0, 0);
|
|
str_i str_j
|
|
unknown NULL
|
|
CALL proc_19194_nested_4(10, 1);
|
|
str_i str_j
|
|
10 NULL
|
|
CALL proc_19194_nested_4(25, 1);
|
|
str_i str_j
|
|
unknown NULL
|
|
CALL proc_19194_nested_4(20, 1);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 1
|
|
CALL proc_19194_nested_4(20, 2);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 2
|
|
CALL proc_19194_nested_4(20, 3);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 3
|
|
CALL proc_19194_nested_4(20, 4);
|
|
i was 20
|
|
i was 20
|
|
str_i str_j
|
|
20 unknown
|
|
CALL proc_19194_nested_4(30, 1);
|
|
str_i str_j
|
|
30 NULL
|
|
CALL proc_19194_nested_4(40, 1);
|
|
str_i str_j
|
|
40 NULL
|
|
CALL proc_19194_nested_4(0, 0);
|
|
str_i str_j
|
|
unknown NULL
|
|
DROP PROCEDURE proc_19194_simple;
|
|
DROP PROCEDURE proc_19194_searched;
|
|
DROP PROCEDURE proc_19194_nested_1;
|
|
DROP PROCEDURE proc_19194_nested_2;
|
|
DROP PROCEDURE proc_19194_nested_3;
|
|
DROP PROCEDURE proc_19194_nested_4;
|
|
DROP PROCEDURE IF EXISTS p1;
|
|
CREATE PROCEDURE p1() CREATE INDEX idx ON t1 (c1);
|
|
SHOW PROCEDURE CODE p1;
|
|
Pos Instruction
|
|
0 stmt 2 "CREATE INDEX idx ON t1 (c1)"
|
|
DROP PROCEDURE p1;
|
|
End of 5.0 tests.
|
|
CREATE PROCEDURE p1()
|
|
BEGIN
|
|
DECLARE dummy int default 0;
|
|
CASE 12
|
|
WHEN 12
|
|
THEN SET dummy = 0;
|
|
END CASE;
|
|
END//
|
|
SHOW PROCEDURE CODE p1;
|
|
Pos Instruction
|
|
0 set dummy@0 0
|
|
1 set_case_expr (6) 0 12
|
|
2 jump_if_not 5(6) (case_expr@0 = 12)
|
|
3 set dummy@0 0
|
|
4 jump 6
|
|
5 error 1339
|
|
DROP PROCEDURE p1;
|