summaryrefslogtreecommitdiff
path: root/mysql-test/t/compound.test
blob: cabdf96e00e69e4538f3ce6b0cb7487b126243a6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
#
# MDEV-5317 Compound statement / anonymous blocks
#
source include/have_log_bin.inc;
delimiter |;

CREATE TABLE t1 (a INT PRIMARY KEY)|

BEGIN NOT ATOMIC
  INSERT INTO t1 VALUES (1);
  INSERT INTO t1 VALUES (2);
  INSERT INTO t1 VALUES (3);
END|

SELECT * FROM t1|
PREPARE stmt FROM "BEGIN NOT ATOMIC
  INSERT INTO t1 VALUES (4);
  INSERT INTO t1 VALUES (5);
  INSERT INTO t1 VALUES (?);
END";
SET @val = 6|
reset master|
EXECUTE stmt USING @val|
SELECT * FROM t1|

# see how ?-placeholder was replaced with the value
delimiter ;|
source include/show_binlog_events.inc;
delimiter |;

DROP TABLE t1|

#
# test for default database
#
# * SP db is different from the current db
CREATE DATABASE mysqltest1|
CREATE PROCEDURE mysqltest1.sp1()
BEGIN
  PREPARE stmt FROM "BEGIN NOT ATOMIC CREATE TABLE t1 AS SELECT DATABASE(); END";
  EXECUTE stmt;
END|

CALL mysqltest1.sp1()|
SELECT * FROM mysqltest1.t1|

USE mysqltest1|
DROP DATABASE mysqltest1|

# * no current db
--error ER_NO_DB_ERROR
BEGIN NOT ATOMIC CREATE TABLE t1(a int); END|

BEGIN NOT ATOMIC SET @a=1; CREATE TABLE test.t1(a int); END|

USE test|
show tables|
drop table t1|

# IF (without /**/ mysqltest treats if as its own command)
/**/ if (select count(*) from information_schema.tables
    where table_schema='test' and table_name='t1') = 0
  then
    create table t1 (a int);
end if|
show tables|
/**/ if (select count(*) from information_schema.tables
    where table_schema='test' and table_name='t1') = 0
  then
    create table t1 (a int);
end if|
show tables|

# CASE simple
case (select table_name from information_schema.tables where table_schema='test')
  when 't1' then create table t2 (b int);
  when 't2' then create table t3 (b int);
  else signal sqlstate '42S02';
end case|
show tables|

# CASE searched
case
  when database() = 'test' then create table t3 (test text);
  when now() < date'2001-02-03' then create table oops (machine time);
end case|
show tables|

# LOOP
--error ER_TABLE_EXISTS_ERROR
loop
  create table t4 (a int);
end loop|
show tables|

# REPEAT
set @a=0;
repeat
  set @a = @a + 1;
until @a > 5
end repeat|
select @a|

# WHILE
--vertical_results
/**/ while (select count(*) from information_schema.tables where table_schema='test')
do
  select concat('drop table ', table_name) into @a
     from information_schema.tables where table_schema='test' limit 1;
  select @a as 'executing:';
  prepare dt from @a;
  execute dt;
end while|
--horizontal_results

# see how ?-placeholder and SP variables are replaced with values
create table t1 (x int)|
create function fn(a int) returns int
begin
  insert t1 values (a+7);
  return a+8;
end|
reset master|
/**/ if fn(9) > 5 then
  select 1;
end if|
prepare stmt from "if fn(?) > 6 then
 begin
  declare a int;
  set a=?*2;
  insert t1 values(a+?);
 end;
end if"|
set @a=1, @b=2, @c=3|
execute stmt using @a, @b, @c|
delimiter ;|
source include/show_binlog_events.inc;
delimiter |;

drop function fn|
drop table t1|

#
# MDEV-6606 Server crashes in String::append on selecting sql_mode inside anonymous block
# MDEV-6609 SQL inside an anonymous block is executed with wrong SQL_MODE
#
begin not atomic select @@sql_mode; end|
create table t1 (a int)|
select a from t1 having a > 1|
begin not atomic select a from t1 having a > 1; end|
drop table t1|

--echo #
--echo # MDEV-8615: Assertion `m_cpp_buf <= begin_ptr &&
--echo # begin_ptr <= m_cpp_buf + m_buf_length' failed in
--echo # Lex_input_stream::body_utf8_start
--echo #
--error ER_PARSE_ERROR
--query b'