1
include/master-slave.inc
3
DROP DATABASE IF EXISTS db1;
4
DROP DATABASE IF EXISTS db2;
8
CREATE TABLE db1.t1 (a INT) ENGINE=InnoDB;
9
CREATE TABLE db1.t2 (s CHAR(255)) ENGINE=MyISAM;
10
include/stop_slave.inc
12
CREATE PROCEDURE db1.p1 ()
14
INSERT INTO t1 VALUES (1);
15
INSERT INTO t1 VALUES (2);
16
INSERT INTO t1 VALUES (3);
17
INSERT INTO t1 VALUES (4);
18
INSERT INTO t1 VALUES (5);
20
CREATE PROCEDURE db1.p2 ()
22
INSERT INTO t1 VALUES (6);
23
INSERT INTO t1 VALUES (7);
24
INSERT INTO t1 VALUES (8);
25
INSERT INTO t1 VALUES (9);
26
INSERT INTO t1 VALUES (10);
27
INSERT INTO t2 VALUES ('executed db1.p2()');
29
INSERT INTO db1.t2 VALUES ('before call db1.p1()');
34
INSERT INTO db1.t2 VALUES ('after call db1.p1()');
47
start slave until master_log_file='master-bin.000001', master_log_pos=MASTER_POS;
48
include/wait_for_slave_sql_to_stop.inc
50
# If we got non-zero here, then we're suffering BUG#43263
52
SELECT 0 as 'Must be 0';
66
INSERT INTO db1.t2 VALUES ('before call db1.p2()');
70
INSERT INTO db1.t2 VALUES ('after call db1.p2()');
86
start slave until master_log_file='master-bin.000001', master_log_pos=MASTER_POS;
87
include/wait_for_slave_sql_to_stop.inc
89
# If we got non-zero here, then we're suffering BUG#43263
91
SELECT 0 as 'Must be 0';
101
SELECT * from db1.t2;
106
include/wait_for_slave_sql_to_start.inc
108
# SAVEPOINT and ROLLBACK TO have the same problem in BUG#43263
109
# This was reported by BUG#50407
111
SET SESSION AUTOCOMMIT=0
113
INSERT INTO db1.t1 VALUES(20);
115
# Verify whether this statement is binlogged correctly
116
/*comment*/ SAVEPOINT has_comment;
118
INSERT INTO db1.t1 VALUES(30);
119
INSERT INTO db1.t2 VALUES("in savepoint has_comment");
121
SavePoint mixed_cases;
123
INSERT INTO db1.t2 VALUES("in savepoint mixed_cases");
124
INSERT INTO db1.t1 VALUES(40);
126
ROLLBACK TO mixed_cases;
128
Warning 1196 Some non-transactional changed tables couldn't be rolled back
129
ROLLBACK TO has_comment;
131
Warning 1196 Some non-transactional changed tables couldn't be rolled back
133
INSERT INTO db1.t2 VALUES("after rollback to");
134
INSERT INTO db1.t1 VALUES(50);
137
show binlog events from <binlog_start>;
138
Log_name Pos Event_type Server_id End_log_pos Info
139
master-bin.000001 # Query # # BEGIN
140
master-bin.000001 # Query # # use `test`; INSERT INTO db1.t1 VALUES(20)
141
master-bin.000001 # Query # # SAVEPOINT `has_comment`
142
master-bin.000001 # Query # # use `db1`; INSERT INTO db1.t1 VALUES(30)
143
master-bin.000001 # Query # # use `db1`; INSERT INTO db1.t2 VALUES("in savepoint has_comment")
144
master-bin.000001 # Query # # SAVEPOINT `mixed_cases`
145
master-bin.000001 # Query # # use `db1`; INSERT INTO db1.t2 VALUES("in savepoint mixed_cases")
146
master-bin.000001 # Query # # use `db1`; INSERT INTO db1.t1 VALUES(40)
147
master-bin.000001 # Query # # ROLLBACK TO `mixed_cases`
148
master-bin.000001 # Query # # ROLLBACK TO `has_comment`
149
master-bin.000001 # Query # # use `db1`; INSERT INTO db1.t2 VALUES("after rollback to")
150
master-bin.000001 # Query # # use `db1`; INSERT INTO db1.t1 VALUES(50)
151
master-bin.000001 # Xid # # COMMIT /* XID */
154
# Verify INSERT statements in savepoints are executed, for MyISAM table
155
# is not effected by ROLLBACK TO
156
SELECT * FROM db1.t2 WHERE s LIKE '% savepoint %';
158
in savepoint has_comment
159
in savepoint mixed_cases
161
# Verify INSERT statements on the Innodb table are rolled back;
162
SELECT * FROM db1.t1 WHERE a IN (30, 40);