mirror of
https://github.com/MariaDB/server.git
synced 2025-01-20 14:02:32 +01:00
3607 lines
94 KiB
Text
3607 lines
94 KiB
Text
SELECT VARIABLE_VALUE from
|
|
INFORMATION_SCHEMA.SESSION_STATUS where variable_name='COM_STMT_REPREPARE'
|
|
into @base_count ;
|
|
set @expected = 0;
|
|
=====================================================================
|
|
Testing 1: NOTHING -> TABLE transitions
|
|
=====================================================================
|
|
drop table if exists t1;
|
|
prepare stmt from 'select * from t1';
|
|
ERROR 42S02: Table 'test.t1' doesn't exist
|
|
=====================================================================
|
|
Testing 2: NOTHING -> TEMPORARY TABLE transitions
|
|
=====================================================================
|
|
=====================================================================
|
|
Testing 3: NOTHING -> VIEW transitions
|
|
=====================================================================
|
|
=====================================================================
|
|
Testing 4: TABLE -> NOTHING transitions
|
|
=====================================================================
|
|
drop table if exists t4;
|
|
create table t4(a int);
|
|
prepare stmt from 'select * from t4';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t4;
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.t4' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.t4' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
=====================================================================
|
|
Testing 5: TABLE -> TABLE (DDL) transitions
|
|
=====================================================================
|
|
drop table if exists t5;
|
|
create table t5(a int);
|
|
prepare stmt from 'select a from t5';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t5 add column (b int);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t5;
|
|
=====================================================================
|
|
Testing 6: TABLE -> TABLE (TRIGGER) transitions
|
|
=====================================================================
|
|
drop table if exists t6;
|
|
create table t6(a int);
|
|
prepare stmt from 'insert into t6(a) value (?)';
|
|
set @val=1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=2;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
create trigger t6_bi before insert on t6 for each row
|
|
begin
|
|
set @message= "t6_bi";
|
|
end
|
|
$$
|
|
set @message="none";
|
|
set @val=3;
|
|
set @expected = @expected + 1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
set @val=4;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
prepare stmt from 'insert into t6(a) value (?)';
|
|
set @message="none";
|
|
set @val=5;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
set @message="none";
|
|
set @val=6;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
create trigger t6_bd before delete on t6 for each row
|
|
begin
|
|
set @message= "t6_bd";
|
|
end
|
|
$$
|
|
set @message="none";
|
|
set @val=7;
|
|
set @expected = @expected + 1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
set @message="none";
|
|
set @val=8;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
prepare stmt from 'insert into t6(a) value (?)';
|
|
set @message="none";
|
|
set @val=9;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
set @message="none";
|
|
set @val=10;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi
|
|
drop trigger t6_bi;
|
|
create trigger t6_bi before insert on t6 for each row
|
|
begin
|
|
set @message= "t6_bi (2)";
|
|
end
|
|
$$
|
|
set @message="none";
|
|
set @val=11;
|
|
set @expected = @expected + 1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
set @val=12;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
prepare stmt from 'insert into t6(a) value (?)';
|
|
set @message="none";
|
|
set @val=13;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
set @message="none";
|
|
set @val=14;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
drop trigger t6_bd;
|
|
create trigger t6_bd before delete on t6 for each row
|
|
begin
|
|
set @message= "t6_bd (2)";
|
|
end
|
|
$$
|
|
set @message="none";
|
|
set @val=15;
|
|
set @expected = @expected + 1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
set @message="none";
|
|
set @val=16;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
prepare stmt from 'insert into t6(a) value (?)';
|
|
set @message="none";
|
|
set @val=17;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
set @message="none";
|
|
set @val=18;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
t6_bi (2)
|
|
drop trigger t6_bi;
|
|
set @message="none";
|
|
set @val=19;
|
|
set @expected = @expected + 1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
none
|
|
set @val=20;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
none
|
|
prepare stmt from 'insert into t6(a) value (?)';
|
|
set @message="none";
|
|
set @val=21;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
none
|
|
set @val=22;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
none
|
|
drop trigger t6_bd;
|
|
set @val=23;
|
|
set @expected = @expected + 1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
none
|
|
set @val=24;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select @message;
|
|
@message
|
|
none
|
|
select * from t6 order by a;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
4
|
|
5
|
|
6
|
|
7
|
|
8
|
|
9
|
|
10
|
|
11
|
|
12
|
|
13
|
|
14
|
|
15
|
|
16
|
|
17
|
|
18
|
|
19
|
|
20
|
|
21
|
|
22
|
|
23
|
|
24
|
|
drop table t6;
|
|
=====================================================================
|
|
Testing 7: TABLE -> TABLE (TRIGGER dependencies) transitions
|
|
=====================================================================
|
|
drop table if exists t7_proc;
|
|
drop table if exists t7_func;
|
|
drop table if exists t7_view;
|
|
drop table if exists t7_table;
|
|
drop table if exists t7_dependent_table;
|
|
drop table if exists t7_table_trigger;
|
|
drop table if exists t7_audit;
|
|
drop procedure if exists audit_proc;
|
|
drop function if exists audit_func;
|
|
drop view if exists audit_view;
|
|
create table t7_proc(a int);
|
|
create table t7_func(a int);
|
|
create table t7_view(a int);
|
|
create table t7_table(a int);
|
|
create table t7_table_trigger(a int);
|
|
create table t7_audit(old_a int, new_a int, reason varchar(50));
|
|
create table t7_dependent_table(old_a int, new_a int, reason varchar(50));
|
|
create procedure audit_proc(a int)
|
|
insert into t7_audit values (NULL, a, "proc v1");
|
|
create function audit_func() returns varchar(50)
|
|
return "func v1";
|
|
create view audit_view as select "view v1" as reason from dual;
|
|
create trigger t7_proc_bi before insert on t7_proc for each row
|
|
call audit_proc(NEW.a);
|
|
create trigger t7_func_bi before insert on t7_func for each row
|
|
insert into t7_audit values (NULL, NEW.a, audit_func());
|
|
create trigger t7_view_bi before insert on t7_view for each row
|
|
insert into t7_audit values (NULL, NEW.a, (select reason from audit_view));
|
|
create trigger t7_table_bi before insert on t7_table for each row
|
|
insert into t7_dependent_table values (NULL, NEW.a, "dependent table");
|
|
create trigger t7_table_trigger_bi before insert on t7_dependent_table
|
|
for each row set NEW.reason="trigger v1";
|
|
prepare stmt_proc from 'insert into t7_proc(a) value (?)';
|
|
set @val=101;
|
|
execute stmt_proc using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=102;
|
|
execute stmt_proc using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop procedure audit_proc;
|
|
create procedure audit_proc(a int)
|
|
insert into t7_audit values (NULL, a, "proc v2");
|
|
set @val=103;
|
|
set @expected = @expected + 1;
|
|
execute stmt_proc using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=104;
|
|
execute stmt_proc using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
prepare stmt_func from 'insert into t7_func(a) value (?)';
|
|
set @val=201;
|
|
execute stmt_func using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=202;
|
|
execute stmt_func using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function audit_func;
|
|
create function audit_func() returns varchar(50)
|
|
return "func v2";
|
|
set @val=203;
|
|
set @expected = @expected + 1;
|
|
execute stmt_func using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=204;
|
|
execute stmt_func using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
prepare stmt_view from 'insert into t7_view(a) value (?)';
|
|
set @val=301;
|
|
execute stmt_view using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=302;
|
|
execute stmt_view using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view audit_view;
|
|
create view audit_view as select "view v2" as reason from dual;
|
|
set @val=303;
|
|
set @expected = @expected + 1;
|
|
execute stmt_view using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=304;
|
|
execute stmt_view using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
prepare stmt_table from 'insert into t7_table(a) value (?)';
|
|
set @val=401;
|
|
execute stmt_table using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=402;
|
|
execute stmt_table using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t7_dependent_table add column comments varchar(100) default NULL;
|
|
set @val=403;
|
|
set @expected = @expected + 1;
|
|
execute stmt_table using @val;
|
|
ERROR 21S01: Column count doesn't match value count at row 1
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=404;
|
|
set @expected = @expected + 1;
|
|
execute stmt_table using @val;
|
|
ERROR 21S01: Column count doesn't match value count at row 1
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t7_dependent_table drop column comments;
|
|
set @val=405;
|
|
set @expected = @expected + 1;
|
|
execute stmt_table using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=406;
|
|
execute stmt_table using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
prepare stmt_table_trigger from 'insert into t7_table(a) value (?)';
|
|
set @val=501;
|
|
execute stmt_table_trigger using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=502;
|
|
execute stmt_table_trigger using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop trigger t7_table_trigger_bi;
|
|
create trigger t7_table_trigger_bi before insert on t7_dependent_table
|
|
for each row set NEW.reason="trigger v2";
|
|
set @val=503;
|
|
set @expected = @expected + 1;
|
|
execute stmt_table_trigger using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=504;
|
|
execute stmt_table_trigger using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select * from t7_audit order by new_a;
|
|
old_a new_a reason
|
|
NULL 101 proc v1
|
|
NULL 102 proc v1
|
|
NULL 103 proc v2
|
|
NULL 104 proc v2
|
|
NULL 201 func v1
|
|
NULL 202 func v1
|
|
NULL 203 func v2
|
|
NULL 204 func v2
|
|
NULL 301 view v1
|
|
NULL 302 view v1
|
|
NULL 303 view v1
|
|
NULL 304 view v1
|
|
select * from t7_dependent_table order by new_a;
|
|
old_a new_a reason
|
|
NULL 401 trigger v1
|
|
NULL 402 trigger v1
|
|
NULL 405 trigger v1
|
|
NULL 406 trigger v1
|
|
NULL 501 trigger v1
|
|
NULL 502 trigger v1
|
|
NULL 503 trigger v2
|
|
NULL 504 trigger v2
|
|
drop table t7_proc;
|
|
drop table t7_func;
|
|
drop table t7_view;
|
|
drop table t7_table;
|
|
drop table t7_dependent_table;
|
|
drop table t7_table_trigger;
|
|
drop table t7_audit;
|
|
drop procedure audit_proc;
|
|
drop function audit_func;
|
|
drop view audit_view;
|
|
=====================================================================
|
|
Testing 8: TABLE -> TEMPORARY TABLE transitions
|
|
=====================================================================
|
|
drop table if exists t8;
|
|
create table t8(a int);
|
|
prepare stmt from 'select * from t8';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t8;
|
|
create temporary table t8(a int);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t8;
|
|
=====================================================================
|
|
Testing 9: TABLE -> VIEW transitions
|
|
=====================================================================
|
|
drop table if exists t9;
|
|
drop table if exists t9_b;
|
|
create table t9(a int);
|
|
create table t9_b(a int);
|
|
prepare stmt from 'select * from t9';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t9;
|
|
create view t9 as select * from t9_b;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view t9;
|
|
drop table t9_b;
|
|
=====================================================================
|
|
Testing 10: TEMPORARY TABLE -> NOTHING transitions
|
|
=====================================================================
|
|
drop temporary table if exists t10;
|
|
create temporary table t10(a int);
|
|
prepare stmt from 'select * from t10';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop temporary table t10;
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.t10' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.t10' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
=====================================================================
|
|
Testing 11: TEMPORARY TABLE -> TABLE transitions
|
|
=====================================================================
|
|
drop table if exists t11;
|
|
drop temporary table if exists t11;
|
|
create table t11(a int);
|
|
insert into t11(a) value (1);
|
|
create temporary table t11(a int);
|
|
prepare stmt from 'select * from t11';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop temporary table t11;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
1
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
1
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select * from t11;
|
|
a
|
|
1
|
|
drop table t11;
|
|
=====================================================================
|
|
Testing 12: TEMPORARY TABLE -> TEMPORARY TABLE (DDL) transitions
|
|
=====================================================================
|
|
drop temporary table if exists t12;
|
|
create temporary table t12(a int);
|
|
prepare stmt from 'select a from t12';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop temporary table t12;
|
|
create temporary table t12(a int, b int);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select * from t12;
|
|
a b
|
|
drop table t12;
|
|
=====================================================================
|
|
Testing 13: TEMPORARY TABLE -> VIEW transitions
|
|
=====================================================================
|
|
drop temporary table if exists t13;
|
|
drop table if exists t13_b;
|
|
create temporary table t13(a int);
|
|
create table t13_b(a int);
|
|
prepare stmt from 'select * from t13';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop temporary table t13;
|
|
create view t13 as select * from t13_b;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view t13;
|
|
drop table t13_b;
|
|
=====================================================================
|
|
Testing 14: VIEW -> NOTHING transitions
|
|
=====================================================================
|
|
drop view if exists t14;
|
|
drop table if exists t14_b;
|
|
create table t14_b(a int);
|
|
create view t14 as select * from t14_b;
|
|
prepare stmt from 'select * from t14';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view t14;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.t14' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.t14' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t14_b;
|
|
=====================================================================
|
|
Testing 15: VIEW -> TABLE transitions
|
|
=====================================================================
|
|
drop view if exists t15;
|
|
drop table if exists t15_b;
|
|
create table t15_b(a int);
|
|
create view t15 as select * from t15_b;
|
|
prepare stmt from 'select * from t15';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view t15;
|
|
create table t15(a int);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t15_b;
|
|
drop table t15;
|
|
=====================================================================
|
|
Testing 16: VIEW -> TEMPORARY TABLE transitions
|
|
=====================================================================
|
|
drop view if exists t16;
|
|
drop table if exists t16_b;
|
|
create table t16_b(a int);
|
|
create view t16 as select * from t16_b;
|
|
prepare stmt from 'select * from t16';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view t16;
|
|
create temporary table t16(a int);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t16_b;
|
|
drop temporary table t16;
|
|
=====================================================================
|
|
Testing 17: VIEW -> VIEW (DDL) transitions
|
|
=====================================================================
|
|
drop view if exists t17;
|
|
drop table if exists t17_b;
|
|
create table t17_b(a int);
|
|
insert into t17_b values (10), (20), (30);
|
|
create view t17 as select a, 2*a as b, 3*a as c from t17_b;
|
|
select * from t17;
|
|
a b c
|
|
10 20 30
|
|
20 40 60
|
|
30 60 90
|
|
prepare stmt from 'select * from t17';
|
|
execute stmt;
|
|
a b c
|
|
10 20 30
|
|
20 40 60
|
|
30 60 90
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b c
|
|
10 20 30
|
|
20 40 60
|
|
30 60 90
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view t17;
|
|
create view t17 as select a, 2*a as b, 5*a as c from t17_b;
|
|
select * from t17;
|
|
a b c
|
|
10 20 50
|
|
20 40 100
|
|
30 60 150
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a b c
|
|
10 20 50
|
|
20 40 100
|
|
30 60 150
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b c
|
|
10 20 50
|
|
20 40 100
|
|
30 60 150
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t17_b;
|
|
drop view t17;
|
|
=====================================================================
|
|
Testing 18: VIEW -> VIEW (VIEW dependencies) transitions
|
|
=====================================================================
|
|
drop table if exists t18;
|
|
drop table if exists t18_dependent_table;
|
|
drop view if exists t18_func;
|
|
drop view if exists t18_view;
|
|
drop view if exists t18_table;
|
|
drop function if exists view_func;
|
|
drop view if exists view_view;
|
|
create table t18(a int);
|
|
insert into t18 values (1), (2), (3);
|
|
create function view_func(x int) returns int
|
|
return x+1;
|
|
create view view_view as select "view v1" as reason from dual;
|
|
create table t18_dependent_table(a int);
|
|
create view t18_func as select a, view_func(a) as b from t18;
|
|
create view t18_view as select a, reason as b from t18, view_view;
|
|
create view t18_table as select * from t18;
|
|
prepare stmt_func from 'select * from t18_func';
|
|
execute stmt_func;
|
|
a b
|
|
1 2
|
|
2 3
|
|
3 4
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_func;
|
|
a b
|
|
1 2
|
|
2 3
|
|
3 4
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function view_func;
|
|
create function view_func(x int) returns int
|
|
return x*x;
|
|
set @expected = @expected + 1;
|
|
execute stmt_func;
|
|
a b
|
|
1 1
|
|
2 4
|
|
3 9
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_func;
|
|
a b
|
|
1 1
|
|
2 4
|
|
3 9
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
prepare stmt_view from 'select * from t18_view';
|
|
execute stmt_view;
|
|
a b
|
|
1 view v1
|
|
2 view v1
|
|
3 view v1
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_view;
|
|
a b
|
|
1 view v1
|
|
2 view v1
|
|
3 view v1
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view view_view;
|
|
create view view_view as select "view v2" as reason from dual;
|
|
set @expected = @expected + 1;
|
|
execute stmt_view;
|
|
a b
|
|
1 view v2
|
|
2 view v2
|
|
3 view v2
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_view;
|
|
a b
|
|
1 view v2
|
|
2 view v2
|
|
3 view v2
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
prepare stmt_table from 'select * from t18_table';
|
|
execute stmt_table;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_table;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t18 add column comments varchar(50) default NULL;
|
|
set @expected = @expected + 1;
|
|
execute stmt_table;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_table;
|
|
a
|
|
1
|
|
2
|
|
3
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t18;
|
|
drop table t18_dependent_table;
|
|
drop view t18_func;
|
|
drop view t18_view;
|
|
drop view t18_table;
|
|
drop function view_func;
|
|
drop view view_view;
|
|
=====================================================================
|
|
Testing 19: Special tables (INFORMATION_SCHEMA)
|
|
=====================================================================
|
|
drop procedure if exists proc_19;
|
|
prepare stmt from
|
|
'select ROUTINE_SCHEMA, ROUTINE_NAME, ROUTINE_TYPE
|
|
from INFORMATION_SCHEMA.ROUTINES where
|
|
routine_name=\'proc_19\'';
|
|
create procedure proc_19() select "hi there";
|
|
execute stmt;
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
test proc_19 PROCEDURE
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
test proc_19 PROCEDURE
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop procedure proc_19;
|
|
create procedure proc_19() select "hi there, again";
|
|
execute stmt;
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
test proc_19 PROCEDURE
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
test proc_19 PROCEDURE
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop procedure proc_19;
|
|
=====================================================================
|
|
Testing 20: Special tables (log tables)
|
|
=====================================================================
|
|
prepare stmt from
|
|
'select * from mysql.general_log where argument=\'IMPOSSIBLE QUERY STRING\'';
|
|
execute stmt;
|
|
event_time user_host thread_id server_id command_type argument
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
event_time user_host thread_id server_id command_type argument
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
event_time user_host thread_id server_id command_type argument
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
event_time user_host thread_id server_id command_type argument
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
=====================================================================
|
|
Testing 21: Special tables (system tables)
|
|
=====================================================================
|
|
drop procedure if exists proc_21;
|
|
prepare stmt from
|
|
'select type, db, name from mysql.proc where name=\'proc_21\'';
|
|
create procedure proc_21() select "hi there";
|
|
execute stmt;
|
|
type db name
|
|
PROCEDURE test proc_21
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
type db name
|
|
PROCEDURE test proc_21
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop procedure proc_21;
|
|
create procedure proc_21() select "hi there, again";
|
|
execute stmt;
|
|
type db name
|
|
PROCEDURE test proc_21
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
type db name
|
|
PROCEDURE test proc_21
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop procedure proc_21;
|
|
=====================================================================
|
|
Testing 22: Special tables (views temp tables)
|
|
=====================================================================
|
|
drop table if exists t22_b;
|
|
drop view if exists t22;
|
|
create table t22_b(a int);
|
|
create algorithm=temptable view t22 as select a*a as a2 from t22_b;
|
|
show create view t22;
|
|
View Create View character_set_client collation_connection
|
|
t22 CREATE ALGORITHM=TEMPTABLE DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `t22` AS select (`t22_b`.`a` * `t22_b`.`a`) AS `a2` from `t22_b` latin1 latin1_swedish_ci
|
|
prepare stmt from 'select * from t22';
|
|
insert into t22_b values (1), (2), (3);
|
|
execute stmt;
|
|
a2
|
|
1
|
|
4
|
|
9
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a2
|
|
1
|
|
4
|
|
9
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
insert into t22_b values (4), (5), (6);
|
|
execute stmt;
|
|
a2
|
|
1
|
|
4
|
|
9
|
|
16
|
|
25
|
|
36
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a2
|
|
1
|
|
4
|
|
9
|
|
16
|
|
25
|
|
36
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t22_b;
|
|
drop view t22;
|
|
=====================================================================
|
|
Testing 23: Special tables (internal join tables)
|
|
=====================================================================
|
|
drop table if exists t23_a;
|
|
drop table if exists t23_b;
|
|
create table t23_a(a int);
|
|
create table t23_b(b int);
|
|
prepare stmt from 'select * from t23_a join t23_b';
|
|
insert into t23_a values (1), (2), (3);
|
|
insert into t23_b values (10), (20), (30);
|
|
execute stmt;
|
|
a b
|
|
1 10
|
|
2 10
|
|
3 10
|
|
1 20
|
|
2 20
|
|
3 20
|
|
1 30
|
|
2 30
|
|
3 30
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b
|
|
1 10
|
|
2 10
|
|
3 10
|
|
1 20
|
|
2 20
|
|
3 20
|
|
1 30
|
|
2 30
|
|
3 30
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
insert into t23_a values (4);
|
|
insert into t23_b values (40);
|
|
execute stmt;
|
|
a b
|
|
1 10
|
|
2 10
|
|
3 10
|
|
4 10
|
|
1 20
|
|
2 20
|
|
3 20
|
|
4 20
|
|
1 30
|
|
2 30
|
|
3 30
|
|
4 30
|
|
1 40
|
|
2 40
|
|
3 40
|
|
4 40
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b
|
|
1 10
|
|
2 10
|
|
3 10
|
|
4 10
|
|
1 20
|
|
2 20
|
|
3 20
|
|
4 20
|
|
1 30
|
|
2 30
|
|
3 30
|
|
4 30
|
|
1 40
|
|
2 40
|
|
3 40
|
|
4 40
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t23_a;
|
|
drop table t23_b;
|
|
=====================================================================
|
|
Testing 24: Special statements
|
|
=====================================================================
|
|
drop table if exists t24_alter;
|
|
create table t24_alter(a int);
|
|
prepare stmt from 'alter table t24_alter add column b int';
|
|
execute stmt;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_alter;
|
|
create table t24_alter(a1 int, a2 int);
|
|
execute stmt;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_alter drop column b;
|
|
execute stmt;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_alter drop column b;
|
|
execute stmt;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_alter;
|
|
drop table if exists t24_repair;
|
|
create table t24_repair(a int);
|
|
insert into t24_repair values (1), (2), (3);
|
|
prepare stmt from 'repair table t24_repair';
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_repair repair status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_repair;
|
|
create table t24_repair(a1 int, a2 int);
|
|
insert into t24_repair values (1, 10), (2, 20), (3, 30);
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_repair repair status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_repair add column b varchar(50) default NULL;
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_repair repair status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_repair drop column b;
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_repair repair status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_repair;
|
|
drop table if exists t24_analyze;
|
|
create table t24_analyze(a int);
|
|
insert into t24_analyze values (1), (2), (3);
|
|
prepare stmt from 'analyze table t24_analyze';
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_analyze analyze status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_analyze;
|
|
create table t24_analyze(a1 int, a2 int);
|
|
insert into t24_analyze values (1, 10), (2, 20), (3, 30);
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_analyze analyze status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_analyze add column b varchar(50) default NULL;
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_analyze analyze status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_analyze drop column b;
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_analyze analyze status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_analyze;
|
|
drop table if exists t24_optimize;
|
|
create table t24_optimize(a int);
|
|
insert into t24_optimize values (1), (2), (3);
|
|
prepare stmt from 'optimize table t24_optimize';
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_optimize optimize status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_optimize;
|
|
create table t24_optimize(a1 int, a2 int);
|
|
insert into t24_optimize values (1, 10), (2, 20), (3, 30);
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_optimize optimize status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_optimize add column b varchar(50) default NULL;
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_optimize optimize status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t24_optimize drop column b;
|
|
execute stmt;
|
|
Table Op Msg_type Msg_text
|
|
test.t24_optimize optimize status OK
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_optimize;
|
|
drop procedure if exists changing_proc;
|
|
prepare stmt from 'show create procedure changing_proc';
|
|
execute stmt;
|
|
ERROR 42000: PROCEDURE changing_proc does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR 42000: PROCEDURE changing_proc does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
create procedure changing_proc() begin end;
|
|
execute stmt;
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
changing_proc CREATE DEFINER=`root`@`localhost` PROCEDURE `changing_proc`()
|
|
begin end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
changing_proc CREATE DEFINER=`root`@`localhost` PROCEDURE `changing_proc`()
|
|
begin end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop procedure changing_proc;
|
|
create procedure changing_proc(x int, y int) begin end;
|
|
execute stmt;
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
changing_proc CREATE DEFINER=`root`@`localhost` PROCEDURE `changing_proc`(x int, y int)
|
|
begin end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
changing_proc CREATE DEFINER=`root`@`localhost` PROCEDURE `changing_proc`(x int, y int)
|
|
begin end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop procedure changing_proc;
|
|
execute stmt;
|
|
ERROR 42000: PROCEDURE changing_proc does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR 42000: PROCEDURE changing_proc does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function if exists changing_func;
|
|
prepare stmt from 'show create function changing_func';
|
|
execute stmt;
|
|
ERROR 42000: FUNCTION changing_func does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR 42000: FUNCTION changing_func does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
create function changing_func() returns int return 0;
|
|
execute stmt;
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
changing_func CREATE DEFINER=`root`@`localhost` FUNCTION `changing_func`() RETURNS int(11)
|
|
return 0 latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
changing_func CREATE DEFINER=`root`@`localhost` FUNCTION `changing_func`() RETURNS int(11)
|
|
return 0 latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function changing_func;
|
|
create function changing_func(x int, y int) returns int return x+y;
|
|
execute stmt;
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
changing_func CREATE DEFINER=`root`@`localhost` FUNCTION `changing_func`(x int, y int) RETURNS int(11)
|
|
return x+y latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
changing_func CREATE DEFINER=`root`@`localhost` FUNCTION `changing_func`(x int, y int) RETURNS int(11)
|
|
return x+y latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function changing_func;
|
|
execute stmt;
|
|
ERROR 42000: FUNCTION changing_func does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR 42000: FUNCTION changing_func does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table if exists t24_trigger;
|
|
create table t24_trigger(a int);
|
|
prepare stmt from 'show create trigger t24_bi;';
|
|
execute stmt;
|
|
ERROR HY000: Trigger does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR HY000: Trigger does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
create trigger t24_bi before insert on t24_trigger for each row
|
|
begin
|
|
set @message= "t24_bi";
|
|
end
|
|
$$
|
|
execute stmt;
|
|
Trigger sql_mode SQL Original Statement character_set_client collation_connection Database Collation
|
|
t24_bi CREATE DEFINER=`root`@`localhost` trigger t24_bi before insert on t24_trigger for each row
|
|
begin
|
|
set @message= "t24_bi";
|
|
end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
Trigger sql_mode SQL Original Statement character_set_client collation_connection Database Collation
|
|
t24_bi CREATE DEFINER=`root`@`localhost` trigger t24_bi before insert on t24_trigger for each row
|
|
begin
|
|
set @message= "t24_bi";
|
|
end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop trigger t24_bi;
|
|
create trigger t24_bi before insert on t24_trigger for each row
|
|
begin
|
|
set @message= "t24_bi (2)";
|
|
end
|
|
$$
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
Trigger sql_mode SQL Original Statement character_set_client collation_connection Database Collation
|
|
t24_bi CREATE DEFINER=`root`@`localhost` trigger t24_bi before insert on t24_trigger for each row
|
|
begin
|
|
set @message= "t24_bi (2)";
|
|
end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
Trigger sql_mode SQL Original Statement character_set_client collation_connection Database Collation
|
|
t24_bi CREATE DEFINER=`root`@`localhost` trigger t24_bi before insert on t24_trigger for each row
|
|
begin
|
|
set @message= "t24_bi (2)";
|
|
end latin1 latin1_swedish_ci latin1_swedish_ci
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop trigger t24_bi;
|
|
execute stmt;
|
|
ERROR HY000: Trigger does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR HY000: Trigger does not exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t24_trigger;
|
|
=====================================================================
|
|
Testing 25: Testing the strength of TABLE_SHARE version
|
|
=====================================================================
|
|
drop table if exists t25_num_col;
|
|
create table t25_num_col(a int);
|
|
prepare stmt from 'select a from t25_num_col';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t25_num_col add column b varchar(50) default NULL;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t25_num_col;
|
|
drop table if exists t25_col_name;
|
|
create table t25_col_name(a int);
|
|
prepare stmt from 'select * from t25_col_name';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t25_col_name change a b int;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t25_col_name;
|
|
drop table if exists t25_col_type;
|
|
create table t25_col_type(a int);
|
|
prepare stmt from 'select * from t25_col_type';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t25_col_type change a a varchar(10);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t25_col_type;
|
|
drop table if exists t25_col_type_length;
|
|
create table t25_col_type_length(a varchar(10));
|
|
prepare stmt from 'select * from t25_col_type_length';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t25_col_type_length change a a varchar(20);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t25_col_type_length;
|
|
drop table if exists t25_col_null;
|
|
create table t25_col_null(a varchar(10));
|
|
prepare stmt from 'select * from t25_col_null';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t25_col_null change a a varchar(10) NOT NULL;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t25_col_null;
|
|
drop table if exists t25_col_default;
|
|
create table t25_col_default(a int, b int DEFAULT 10);
|
|
prepare stmt from 'insert into t25_col_default(a) values (?)';
|
|
set @val=1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=2;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t25_col_default change b b int DEFAULT 20;
|
|
set @val=3;
|
|
set @expected = @expected + 1;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @val=4;
|
|
execute stmt using @val;
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
select * from t25_col_default;
|
|
a b
|
|
1 10
|
|
2 10
|
|
3 20
|
|
4 20
|
|
drop table t25_col_default;
|
|
drop table if exists t25_index;
|
|
create table t25_index(a varchar(10));
|
|
prepare stmt from 'select * from t25_index';
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
create index i1 on t25_index(a);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t25_index;
|
|
drop table if exists t25_index_unique;
|
|
create table t25_index_unique(a varchar(10), b varchar(10));
|
|
create index i1 on t25_index_unique(a, b);
|
|
show create table t25_index_unique;
|
|
Table Create Table
|
|
t25_index_unique CREATE TABLE `t25_index_unique` (
|
|
`a` varchar(10) DEFAULT NULL,
|
|
`b` varchar(10) DEFAULT NULL,
|
|
KEY `i1` (`a`,`b`)
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
prepare stmt from 'select * from t25_index_unique';
|
|
execute stmt;
|
|
a b
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
alter table t25_index_unique drop index i1;
|
|
create unique index i1 on t25_index_unique(a, b);
|
|
show create table t25_index_unique;
|
|
Table Create Table
|
|
t25_index_unique CREATE TABLE `t25_index_unique` (
|
|
`a` varchar(10) DEFAULT NULL,
|
|
`b` varchar(10) DEFAULT NULL,
|
|
UNIQUE KEY `i1` (`a`,`b`)
|
|
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a b
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t25_index_unique;
|
|
=====================================================================
|
|
Testing reported bugs
|
|
=====================================================================
|
|
drop table if exists table_12093;
|
|
drop function if exists func_12093;
|
|
drop function if exists func_12093_unrelated;
|
|
drop procedure if exists proc_12093;
|
|
create table table_12093(a int);
|
|
create function func_12093()
|
|
returns int
|
|
begin
|
|
return (select count(*) from table_12093);
|
|
end//
|
|
create procedure proc_12093(a int)
|
|
begin
|
|
select * from table_12093;
|
|
end//
|
|
create function func_12093_unrelated() returns int return 2;
|
|
create procedure proc_12093_unrelated() begin end;
|
|
prepare stmt_sf from 'select func_12093();';
|
|
prepare stmt_sp from 'call proc_12093(func_12093())';
|
|
execute stmt_sf;
|
|
func_12093()
|
|
0
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_sp;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function func_12093_unrelated;
|
|
drop procedure proc_12093_unrelated;
|
|
execute stmt_sf;
|
|
func_12093()
|
|
0
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_sp;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_sf;
|
|
func_12093()
|
|
0
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt_sp;
|
|
a
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
deallocate prepare stmt_sf;
|
|
deallocate prepare stmt_sp;
|
|
drop table table_12093;
|
|
drop function func_12093;
|
|
drop procedure proc_12093;
|
|
drop function if exists func_21294;
|
|
create function func_21294() returns int return 10;
|
|
prepare stmt from "select func_21294()";
|
|
execute stmt;
|
|
func_21294()
|
|
10
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function func_21294;
|
|
create function func_21294() returns int return 10;
|
|
execute stmt;
|
|
func_21294()
|
|
10
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop function func_21294;
|
|
create function func_21294() returns int return 20;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
func_21294()
|
|
20
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
deallocate prepare stmt;
|
|
drop function func_21294;
|
|
drop table if exists t_27420_100;
|
|
drop table if exists t_27420_101;
|
|
drop view if exists v_27420;
|
|
create table t_27420_100(a int);
|
|
insert into t_27420_100 values (1), (2);
|
|
create table t_27420_101(a int);
|
|
insert into t_27420_101 values (1), (2);
|
|
create view v_27420 as select t_27420_100.a X, t_27420_101.a Y
|
|
from t_27420_100, t_27420_101
|
|
where t_27420_100.a=t_27420_101.a;
|
|
prepare stmt from 'select * from v_27420';
|
|
execute stmt;
|
|
X Y
|
|
1 1
|
|
2 2
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop view v_27420;
|
|
create table v_27420(X int, Y int);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
X Y
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table v_27420;
|
|
create table v_27420 (a int, b int, filler char(200));
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
deallocate prepare stmt;
|
|
drop table t_27420_100;
|
|
drop table t_27420_101;
|
|
drop table v_27420;
|
|
drop table if exists t_27430_1;
|
|
drop table if exists t_27430_2;
|
|
create table t_27430_1 (a int not null, oref int not null, key(a));
|
|
insert into t_27430_1 values
|
|
(1, 1),
|
|
(1, 1234),
|
|
(2, 3),
|
|
(2, 1234),
|
|
(3, 1234);
|
|
create table t_27430_2 (a int not null, oref int not null);
|
|
insert into t_27430_2 values
|
|
(1, 1),
|
|
(2, 2),
|
|
(1234, 3),
|
|
(1234, 4);
|
|
prepare stmt from
|
|
'select oref, a, a in (select a from t_27430_1 where oref=t_27430_2.oref) Z from t_27430_2';
|
|
execute stmt;
|
|
oref a Z
|
|
1 1 1
|
|
2 2 0
|
|
3 1234 0
|
|
4 1234 0
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
oref a Z
|
|
1 1 1
|
|
2 2 0
|
|
3 1234 0
|
|
4 1234 0
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table t_27430_1, t_27430_2;
|
|
create table t_27430_1 (a int, oref int, key(a));
|
|
insert into t_27430_1 values
|
|
(1, 1),
|
|
(1, NULL),
|
|
(2, 3),
|
|
(2, NULL),
|
|
(3, NULL);
|
|
create table t_27430_2 (a int, oref int);
|
|
insert into t_27430_2 values
|
|
(1, 1),
|
|
(2,2),
|
|
(NULL, 3),
|
|
(NULL, 4);
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
ERROR HY000: Prepared statement result set has changed, rebind needed
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
deallocate prepare stmt;
|
|
drop table t_27430_1;
|
|
drop table t_27430_2;
|
|
drop table if exists t_27690_1;
|
|
drop view if exists v_27690_1;
|
|
drop table if exists v_27690_2;
|
|
create table t_27690_1 (a int, b int);
|
|
insert into t_27690_1 values (1,1),(2,2);
|
|
create table v_27690_1 as select * from t_27690_1;
|
|
create table v_27690_2 as select * from t_27690_1;
|
|
prepare stmt from 'select * from v_27690_1, v_27690_2';
|
|
execute stmt;
|
|
a b a b
|
|
1 1 1 1
|
|
2 2 1 1
|
|
1 1 2 2
|
|
2 2 2 2
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b a b
|
|
1 1 1 1
|
|
2 2 1 1
|
|
1 1 2 2
|
|
2 2 2 2
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
drop table v_27690_1;
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.v_27690_1' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
ERROR 42S02: Table 'test.v_27690_1' doesn't exist
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
create view v_27690_1 as select A.a, A.b from t_27690_1 A, t_27690_1 B;
|
|
set @expected = @expected + 1;
|
|
execute stmt;
|
|
a b a b
|
|
1 1 1 1
|
|
2 2 1 1
|
|
1 1 1 1
|
|
2 2 1 1
|
|
1 1 2 2
|
|
2 2 2 2
|
|
1 1 2 2
|
|
2 2 2 2
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
execute stmt;
|
|
a b a b
|
|
1 1 1 1
|
|
2 2 1 1
|
|
1 1 1 1
|
|
2 2 1 1
|
|
1 1 2 2
|
|
2 2 2 2
|
|
1 1 2 2
|
|
2 2 2 2
|
|
SELECT CASE (VARIABLE_VALUE - @base_count - @expected)
|
|
WHEN 0 THEN "PASSED"
|
|
ELSE "FAILED"
|
|
END
|
|
AS `CHECK`,
|
|
(VARIABLE_VALUE - @base_count - @expected) AS `OFFSET`
|
|
from INFORMATION_SCHEMA.SESSION_STATUS
|
|
where variable_name='COM_STMT_REPREPARE' ;
|
|
CHECK OFFSET
|
|
PASSED 0
|
|
deallocate prepare stmt;
|
|
drop table t_27690_1;
|
|
drop view v_27690_1;
|
|
drop table v_27690_2;
|