2
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
5
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
7
**** Resetting master and slave ****
11
include/start_slave.inc
12
CREATE TABLE t1 (a INT, b INT);
13
CREATE TABLE t2 (a INT, b INT) ENGINE=Merge;
14
CREATE TABLE t3 (a INT, b INT) CHARSET=utf8;
15
CREATE TABLE t4 (a INT, b INT) ENGINE=Merge CHARSET=utf8;
16
SHOW BINLOG EVENTS FROM 106;
22
Info use `test`; CREATE TABLE t1 (a INT, b INT)
28
Info use `test`; CREATE TABLE t2 (a INT, b INT) ENGINE=Merge
34
Info use `test`; CREATE TABLE t3 (a INT, b INT) CHARSET=utf8
40
Info use `test`; CREATE TABLE t4 (a INT, b INT) ENGINE=Merge CHARSET=utf8
44
Create Table CREATE TABLE `t1` (
45
`a` int(11) DEFAULT NULL,
46
`b` int(11) DEFAULT NULL
47
) ENGINE=MyISAM DEFAULT CHARSET=latin1
50
Create Table CREATE TABLE `t2` (
51
`a` int(11) DEFAULT NULL,
52
`b` int(11) DEFAULT NULL
53
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
56
Create Table CREATE TABLE `t3` (
57
`a` int(11) DEFAULT NULL,
58
`b` int(11) DEFAULT NULL
59
) ENGINE=MyISAM DEFAULT CHARSET=utf8
63
Create Table CREATE TABLE `t1` (
64
`a` int(11) DEFAULT NULL,
65
`b` int(11) DEFAULT NULL
66
) ENGINE=MEMORY DEFAULT CHARSET=latin1
69
Create Table CREATE TABLE `t2` (
70
`a` int(11) DEFAULT NULL,
71
`b` int(11) DEFAULT NULL
72
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1
75
Create Table CREATE TABLE `t3` (
76
`a` int(11) DEFAULT NULL,
77
`b` int(11) DEFAULT NULL
78
) ENGINE=MEMORY DEFAULT CHARSET=utf8
79
CREATE TABLE t5 (b INT, c INT) SELECT * FROM t3;
80
CREATE TEMPORARY TABLE tt3 (a INT, b INT);
81
INSERT INTO tt3 VALUES (1,2), (2,4), (3,6), (4,2), (5,10), (6,12);
82
CREATE TABLE t6 (b INT, c INT) SELECT * FROM tt3;
86
Create Table CREATE TABLE `t5` (
87
`c` int(11) DEFAULT NULL,
88
`a` int(11) DEFAULT NULL,
89
`b` int(11) DEFAULT NULL
90
) ENGINE=MyISAM DEFAULT CHARSET=latin1
91
SELECT * FROM t5 ORDER BY a,b,c;
95
Create Table CREATE TABLE `t6` (
96
`c` int(11) DEFAULT NULL,
97
`a` int(11) DEFAULT NULL,
98
`b` int(11) DEFAULT NULL
99
) ENGINE=MyISAM DEFAULT CHARSET=latin1
100
SELECT * FROM t6 ORDER BY a,b,c;
109
SHOW CREATE TABLE t5;
111
Create Table CREATE TABLE `t5` (
112
`c` int(11) DEFAULT NULL,
113
`a` int(11) DEFAULT NULL,
114
`b` int(11) DEFAULT NULL
115
) ENGINE=MEMORY DEFAULT CHARSET=latin1
116
SELECT * FROM t5 ORDER BY a,b,c;
118
SHOW CREATE TABLE t6;
120
Create Table CREATE TABLE `t6` (
121
`c` int(11) DEFAULT NULL,
122
`a` int(11) DEFAULT NULL,
123
`b` int(11) DEFAULT NULL
124
) ENGINE=MEMORY DEFAULT CHARSET=latin1
125
SELECT * FROM t6 ORDER BY a,b,c;
133
**** Resetting master and slave ****
134
include/stop_slave.inc
137
include/start_slave.inc
138
CREATE TABLE t7 (UNIQUE(b)) SELECT a,b FROM tt3;
139
ERROR 23000: Duplicate entry '2' for key 'b'
140
SHOW BINLOG EVENTS FROM 106;
141
Log_name Pos Event_type Server_id End_log_pos Info
142
CREATE TABLE t7 (a INT, b INT UNIQUE);
143
INSERT INTO t7 SELECT a,b FROM tt3;
144
ERROR 23000: Duplicate entry '2' for key 'b'
145
SELECT * FROM t7 ORDER BY a,b;
150
SHOW BINLOG EVENTS FROM 106;
151
Log_name Pos Event_type Server_id End_log_pos Info
152
# 106 Query # 206 use `test`; CREATE TABLE t7 (a INT, b INT UNIQUE)
153
# 206 Query # 274 BEGIN
154
# 274 Table_map # 316 table_id: # (test.t7)
155
# 316 Write_rows # 372 table_id: # flags: STMT_END_F
156
# 372 Query # 443 ROLLBACK
157
SELECT * FROM t7 ORDER BY a,b;
162
**** Resetting master and slave ****
163
include/stop_slave.inc
166
include/start_slave.inc
167
CREATE TEMPORARY TABLE tt4 (a INT, b INT);
168
INSERT INTO tt4 VALUES (4,8), (5,10), (6,12);
170
INSERT INTO t7 SELECT a,b FROM tt4;
173
Warning 1196 Some non-transactional changed tables couldn't be rolled back
174
SHOW BINLOG EVENTS FROM 106;
175
Log_name Pos Event_type Server_id End_log_pos Info
176
# 106 Query # 174 BEGIN
177
# 174 Table_map # 216 table_id: # (test.t7)
178
# 216 Write_rows # 272 table_id: # flags: STMT_END_F
179
# 272 Query # 341 COMMIT
180
SELECT * FROM t7 ORDER BY a,b;
188
SELECT * FROM t7 ORDER BY a,b;
196
**** Resetting master and slave ****
197
include/stop_slave.inc
200
include/start_slave.inc
201
CREATE TABLE t8 LIKE t4;
202
CREATE TABLE t9 LIKE tt4;
203
CREATE TEMPORARY TABLE tt5 LIKE t4;
204
CREATE TEMPORARY TABLE tt6 LIKE tt4;
205
CREATE TEMPORARY TABLE tt7 SELECT 1;
207
SHOW CREATE TABLE t8;
209
Create Table CREATE TABLE `t8` (
210
`a` int(11) DEFAULT NULL,
211
`b` int(11) DEFAULT NULL
212
) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8
213
SHOW CREATE TABLE t9;
215
Create Table CREATE TABLE `t9` (
216
`a` int(11) DEFAULT NULL,
217
`b` int(11) DEFAULT NULL
218
) ENGINE=MyISAM DEFAULT CHARSET=latin1
219
SHOW BINLOG EVENTS FROM 106;
220
Log_name Pos Event_type Server_id End_log_pos Info
221
# 106 Query # 192 use `test`; CREATE TABLE t8 LIKE t4
222
# 192 Query # 331 use `test`; CREATE TABLE `t9` (
223
`a` int(11) DEFAULT NULL,
224
`b` int(11) DEFAULT NULL
227
SHOW CREATE TABLE t8;
229
Create Table CREATE TABLE `t8` (
230
`a` int(11) DEFAULT NULL,
231
`b` int(11) DEFAULT NULL
232
) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8
233
SHOW CREATE TABLE t9;
235
Create Table CREATE TABLE `t9` (
236
`a` int(11) DEFAULT NULL,
237
`b` int(11) DEFAULT NULL
238
) ENGINE=MEMORY DEFAULT CHARSET=latin1
239
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8,t9;
241
SET GLOBAL storage_engine=@storage_engine;
243
================ BUG#22864 ================
249
CREATE TABLE t1 (a INT);
250
INSERT INTO t1 VALUES (1),(2),(3);
251
CREATE TABLE t2 ENGINE=INNODB SELECT * FROM t1;
253
CREATE TABLE t3 ENGINE=INNODB SELECT * FROM t1;
254
INSERT INTO t3 VALUES (4),(5),(6);
256
CREATE TABLE t4 ENGINE=INNODB SELECT * FROM t1;
257
INSERT INTO t1 VALUES (4),(5),(6);
260
Warning 1196 Some non-transactional changed tables couldn't be rolled back
267
SELECT TABLE_NAME,ENGINE
268
FROM INFORMATION_SCHEMA.TABLES
269
WHERE TABLE_NAME LIKE 't_'
276
SELECT * FROM t1 ORDER BY a;
284
SELECT * FROM t2 ORDER BY a;
289
SELECT * FROM t3 ORDER BY a;
294
SELECT * FROM t4 ORDER BY a;
299
SHOW BINLOG EVENTS FROM 106;
300
Log_name Pos Event_type Server_id End_log_pos Info
301
# 106 Query # 192 use `test`; CREATE TABLE t1 (a INT)
302
# 192 Query # 260 BEGIN
303
# 260 Table_map # 301 table_id: # (test.t1)
304
# 301 Write_rows # 345 table_id: # flags: STMT_END_F
305
# 345 Query # 414 COMMIT
306
# 414 Query # 482 BEGIN
307
# 482 Query # 607 use `test`; CREATE TABLE `t2` (
308
`a` int(11) DEFAULT NULL
310
# 607 Table_map # 648 table_id: # (test.t2)
311
# 648 Write_rows # 692 table_id: # flags: STMT_END_F
312
# 692 Xid # 719 COMMIT /* XID */
313
# 719 Query # 787 BEGIN
314
# 787 Query # 912 use `test`; CREATE TABLE `t3` (
315
`a` int(11) DEFAULT NULL
317
# 912 Table_map # 953 table_id: # (test.t3)
318
# 953 Write_rows # 997 table_id: # flags: STMT_END_F
319
# 997 Xid # 1024 COMMIT /* XID */
320
# 1024 Query # 1092 BEGIN
321
# 1092 Query # 1217 use `test`; CREATE TABLE `t4` (
322
`a` int(11) DEFAULT NULL
324
# 1217 Table_map # 1258 table_id: # (test.t4)
325
# 1258 Write_rows # 1302 table_id: # flags: STMT_END_F
326
# 1302 Xid # 1329 COMMIT /* XID */
327
# 1329 Query # 1397 BEGIN
328
# 1397 Table_map # 1438 table_id: # (test.t1)
329
# 1438 Write_rows # 1482 table_id: # flags: STMT_END_F
330
# 1482 Query # 1551 COMMIT
337
SELECT TABLE_NAME,ENGINE
338
FROM INFORMATION_SCHEMA.TABLES
339
WHERE TABLE_NAME LIKE 't_'
346
SELECT * FROM t1 ORDER BY a;
354
SELECT * FROM t2 ORDER BY a;
359
SELECT * FROM t3 ORDER BY a;
364
SELECT * FROM t4 ORDER BY a;
369
DROP TABLE IF EXISTS t1,t2,t3,t4;
375
CREATE TABLE t1 (a INT);
376
INSERT INTO t1 VALUES (1),(2),(3);
377
CREATE TABLE t2 (a INT) ENGINE=INNODB;
379
INSERT INTO t2 SELECT a*a FROM t1;
380
CREATE TEMPORARY TABLE tt1
384
INSERT INTO t2 SELECT a+2 FROM tt1;
386
SELECT * FROM t2 ORDER BY a;
393
SHOW BINLOG EVENTS FROM 106;
394
Log_name Pos Event_type Server_id End_log_pos Info
395
# 106 Query # 192 use `test`; CREATE TABLE t1 (a INT)
396
# 192 Query # 260 BEGIN
397
# 260 Table_map # 301 table_id: # (test.t1)
398
# 301 Write_rows # 345 table_id: # flags: STMT_END_F
399
# 345 Query # 414 COMMIT
400
# 414 Query # 514 use `test`; CREATE TABLE t2 (a INT) ENGINE=INNODB
401
# 514 Query # 582 BEGIN
402
# 582 Table_map # 623 table_id: # (test.t2)
403
# 623 Write_rows # 667 table_id: # flags: STMT_END_F
404
# 667 Table_map # 708 table_id: # (test.t2)
405
# 708 Write_rows # 747 table_id: # flags: STMT_END_F
406
# 747 Xid # 774 COMMIT /* XID */
407
SELECT * FROM t2 ORDER BY a;
415
**** Resetting master and slave ****
416
include/stop_slave.inc
419
include/start_slave.inc
421
INSERT INTO t2 SELECT a*a FROM t1;
422
CREATE TEMPORARY TABLE tt2
426
INSERT INTO t2 SELECT a+2 FROM tt2;
429
Warning 1196 Some non-transactional changed tables couldn't be rolled back
430
SELECT * FROM t2 ORDER BY a;
432
SHOW BINLOG EVENTS FROM 106;
433
Log_name Pos Event_type Server_id End_log_pos Info
434
# 106 Query # 174 BEGIN
435
# 174 Table_map # 215 table_id: # (test.t2)
436
# 215 Write_rows # 259 table_id: # flags: STMT_END_F
437
# 259 Table_map # 300 table_id: # (test.t2)
438
# 300 Write_rows # 339 table_id: # flags: STMT_END_F
439
# 339 Query # 410 ROLLBACK
440
SELECT * FROM t2 ORDER BY a;
443
CREATE TABLE t1 (a INT);
444
INSERT INTO t1 VALUES (1),(1);
445
CREATE TABLE t2 (a INT UNIQUE) ENGINE=INNODB SELECT * FROM t1;
446
ERROR 23000: Duplicate entry '1' for key 'a'
447
INSERT INTO t1 VALUES (2);
448
*** the proof of the fix:
449
select must show that the last insert performed on the slave ***
457
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
460
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
462
DROP DATABASE IF EXISTS mysqltest1;
463
CREATE DATABASE mysqltest1;
464
CREATE TABLE mysqltest1.without_select (f1 BIGINT);
465
CREATE TABLE mysqltest1.with_select AS SELECT 1 AS f1;
466
show binlog events from <binlog_start>;
467
Log_name Pos Event_type Server_id End_log_pos Info
468
master-bin.000001 # Query # # DROP DATABASE IF EXISTS mysqltest1
469
master-bin.000001 # Query # # CREATE DATABASE mysqltest1
470
master-bin.000001 # Query # # use `test`; CREATE TABLE mysqltest1.without_select (f1 BIGINT)
471
master-bin.000001 # Query # # BEGIN
472
master-bin.000001 # Query # # use `test`; CREATE TABLE `mysqltest1`.`with_select` (
473
`f1` int(1) NOT NULL DEFAULT '0'
475
master-bin.000001 # Table_map # # table_id: # (mysqltest1.with_select)
476
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
477
master-bin.000001 # Query # # COMMIT
478
DROP DATABASE mysqltest1;
480
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
483
drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9;
485
CREATE TEMPORARY TABLE t7(c1 INT);
486
CREATE TABLE t5(c1 INT);
487
CREATE TABLE t4(c1 INT);
488
CREATE VIEW bug48506_t1 AS SELECT 1;
489
CREATE VIEW bug48506_t2 AS SELECT * FROM t4;
490
CREATE VIEW bug48506_t3 AS SELECT t5.c1 AS A, t4.c1 AS B FROM t5, t4;
491
CREATE TABLE bug48506_t4(c1 INT);
492
DROP VIEW bug48506_t1, bug48506_t2, bug48506_t3;
493
DROP TABLE bug48506_t4;
494
CREATE TABLE IF NOT EXISTS bug48506_t1 LIKE t7;
495
CREATE TABLE IF NOT EXISTS bug48506_t2 LIKE t7;
496
CREATE TABLE IF NOT EXISTS bug48506_t3 LIKE t7;
497
CREATE TABLE IF NOT EXISTS bug48506_t4 LIKE t7;
498
SHOW TABLES LIKE 'bug48506%';
499
Tables_in_test (bug48506%)
501
DROP VIEW IF EXISTS bug48506_t1, bug48506_t2, bug48506_t3;
502
DROP TEMPORARY TABLES t7;
504
DROP TABLES IF EXISTS bug48506_t4;