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
CREATE TABLE t1 (C1 CHAR(1), C2 CHAR(1), INDEX (C1)) ENGINE = 'MYISAM' ;
12
INSERT INTO t1 VALUES ('A','B'), ('X','Y'), ('X','X');
13
INSERT INTO t1 VALUES ('A','C'), ('X','Z'), ('A','A');
14
SELECT * FROM t1 ORDER BY C1,C2;
22
SELECT * FROM t1 ORDER BY C1,C2;
30
DELETE FROM t1 WHERE C1 = C2;
31
SELECT * FROM t1 ORDER BY C1,C2;
37
SELECT * FROM t1 ORDER BY C1,C2;
43
UPDATE t1 SET C2 = 'I' WHERE C1 = 'A' AND C2 = 'C';
44
SELECT * FROM t1 ORDER BY C1,C2;
50
SELECT * FROM t1 ORDER BY C1,C2;
56
UPDATE t1 SET c2 = 'Q' WHERE c1 = 'A' AND c2 = 'N';
57
SELECT * FROM t1 ORDER BY c1,c2;
63
SELECT * FROM t1 ORDER BY c1,c2;
69
CREATE TABLE t2 (c1 INT, c12 char(1), c2 INT, PRIMARY KEY (c1)) ENGINE = 'MYISAM' ;
71
VALUES (1,'A',2), (2,'A',4), (3,'A',9), (4,'A',15), (5,'A',25),
72
(6,'A',35), (7,'A',50), (8,'A',64), (9,'A',81);
73
SELECT * FROM t2 ORDER BY c1,c2;
84
SELECT * FROM t2 WHERE c2 = c1 * c1 ORDER BY c1,c2;
91
SELECT * FROM t2 ORDER BY c1,c2;
102
SELECT * FROM t2 WHERE c2 = c1 * c1 ORDER BY c1,c2;
109
UPDATE t2 SET c2 = c1*c1 WHERE c2 != c1*c1;
110
SELECT * FROM t2 WHERE c2 = c1 * c1 ORDER BY c1,c2;
121
SELECT * FROM t2 WHERE c2 = c1 * c1 ORDER BY c1,c2;
132
UPDATE t2 SET c12 = 'Q' WHERE c1 = 1 AND c2 = 999;
133
SELECT * FROM t2 ORDER BY c1,c2;
144
SELECT * FROM t2 ORDER BY c1,c2;
155
DELETE FROM t2 WHERE c1 % 4 = 0;
156
SELECT * FROM t2 ORDER BY c1,c2;
165
SELECT * FROM t2 ORDER BY c1,c2;
174
UPDATE t2 SET c12='X';
175
CREATE TABLE t3 (C1 CHAR(1), C2 CHAR(1), pk1 INT, C3 CHAR(1), pk2 INT, PRIMARY KEY (pk1,pk2)) ENGINE = 'MYISAM' ;
176
INSERT INTO t3 VALUES ('A','B',1,'B',1), ('X','Y',2,'B',1), ('X','X',3,'B',1);
177
INSERT INTO t3 VALUES ('A','C',1,'B',2), ('X','Z',2,'B',2), ('A','A',3,'B',2);
178
SELECT * FROM t3 ORDER BY C1,C2;
186
SELECT * FROM t3 ORDER BY C1,C2;
194
DELETE FROM t3 WHERE C1 = C2;
195
SELECT * FROM t3 ORDER BY C1,C2;
201
SELECT * FROM t3 ORDER BY C1,C2;
207
UPDATE t3 SET C2 = 'I' WHERE C1 = 'A' AND C2 = 'C';
208
SELECT * FROM t3 ORDER BY C1,C2;
214
SELECT * FROM t3 ORDER BY C1,C2;
220
CREATE TABLE t6 (C1 CHAR(1), C2 CHAR(1), C3 INT) ENGINE = 'MYISAM' ;
221
INSERT INTO t6 VALUES ('A','B',1), ('X','Y',2), ('X','X',3);
222
INSERT INTO t6 VALUES ('A','C',4), ('X','Z',5), ('A','A',6);
223
SELECT * FROM t6 ORDER BY C3;
231
SELECT * FROM t6 ORDER BY C3;
239
DELETE FROM t6 WHERE C1 = C2;
240
SELECT * FROM t6 ORDER BY C3;
246
SELECT * FROM t6 ORDER BY C3;
252
UPDATE t6 SET C2 = 'I' WHERE C1 = 'A' AND C2 = 'C';
253
SELECT * FROM t6 ORDER BY C3;
259
SELECT * FROM t6 ORDER BY C3;
265
CREATE TABLE t5 (C1 CHAR(1), C2 CHAR(1), C3 INT PRIMARY KEY) ENGINE = 'MYISAM' ;
266
INSERT INTO t5 VALUES ('A','B',1), ('X','Y',2), ('X','X',3);
267
INSERT INTO t5 VALUES ('A','C',4), ('X','Z',5), ('A','A',6);
268
UPDATE t5,t2,t3 SET t5.C2='Q', t2.c12='R', t3.C3 ='S' WHERE t5.C1 = t2.c12 AND t5.C1 = t3.C1;
269
SELECT * FROM t5,t2,t3 WHERE t5.C2='Q' AND t2.c12='R' AND t3.C3 ='S' ORDER BY t5.C3,t2.c1,t3.pk1,t3.pk2;
270
C1 C2 C3 c1 c12 c2 C1 C2 pk1 C3 pk2
271
X Q 2 1 R 1 X Y 2 S 1
272
X Q 2 1 R 1 X Z 2 S 2
273
X Q 2 2 R 4 X Y 2 S 1
274
X Q 2 2 R 4 X Z 2 S 2
275
X Q 2 3 R 9 X Y 2 S 1
276
X Q 2 3 R 9 X Z 2 S 2
277
X Q 2 5 R 25 X Y 2 S 1
278
X Q 2 5 R 25 X Z 2 S 2
279
X Q 2 6 R 36 X Y 2 S 1
280
X Q 2 6 R 36 X Z 2 S 2
281
X Q 2 7 R 49 X Y 2 S 1
282
X Q 2 7 R 49 X Z 2 S 2
283
X Q 2 9 R 81 X Y 2 S 1
284
X Q 2 9 R 81 X Z 2 S 2
285
X Q 3 1 R 1 X Y 2 S 1
286
X Q 3 1 R 1 X Z 2 S 2
287
X Q 3 2 R 4 X Y 2 S 1
288
X Q 3 2 R 4 X Z 2 S 2
289
X Q 3 3 R 9 X Y 2 S 1
290
X Q 3 3 R 9 X Z 2 S 2
291
X Q 3 5 R 25 X Y 2 S 1
292
X Q 3 5 R 25 X Z 2 S 2
293
X Q 3 6 R 36 X Y 2 S 1
294
X Q 3 6 R 36 X Z 2 S 2
295
X Q 3 7 R 49 X Y 2 S 1
296
X Q 3 7 R 49 X Z 2 S 2
297
X Q 3 9 R 81 X Y 2 S 1
298
X Q 3 9 R 81 X Z 2 S 2
299
X Q 5 1 R 1 X Y 2 S 1
300
X Q 5 1 R 1 X Z 2 S 2
301
X Q 5 2 R 4 X Y 2 S 1
302
X Q 5 2 R 4 X Z 2 S 2
303
X Q 5 3 R 9 X Y 2 S 1
304
X Q 5 3 R 9 X Z 2 S 2
305
X Q 5 5 R 25 X Y 2 S 1
306
X Q 5 5 R 25 X Z 2 S 2
307
X Q 5 6 R 36 X Y 2 S 1
308
X Q 5 6 R 36 X Z 2 S 2
309
X Q 5 7 R 49 X Y 2 S 1
310
X Q 5 7 R 49 X Z 2 S 2
311
X Q 5 9 R 81 X Y 2 S 1
312
X Q 5 9 R 81 X Z 2 S 2
313
SELECT * FROM t5,t2,t3 WHERE t5.C2='Q' AND t2.c12='R' AND t3.C3 ='S' ORDER BY t5.C3,t2.c1,t3.pk1,t3.pk2;
314
C1 C2 C3 c1 c12 c2 C1 C2 pk1 C3 pk2
315
X Q 2 1 R 1 X Y 2 S 1
316
X Q 2 1 R 1 X Z 2 S 2
317
X Q 2 2 R 4 X Y 2 S 1
318
X Q 2 2 R 4 X Z 2 S 2
319
X Q 2 3 R 9 X Y 2 S 1
320
X Q 2 3 R 9 X Z 2 S 2
321
X Q 2 5 R 25 X Y 2 S 1
322
X Q 2 5 R 25 X Z 2 S 2
323
X Q 2 6 R 36 X Y 2 S 1
324
X Q 2 6 R 36 X Z 2 S 2
325
X Q 2 7 R 49 X Y 2 S 1
326
X Q 2 7 R 49 X Z 2 S 2
327
X Q 2 9 R 81 X Y 2 S 1
328
X Q 2 9 R 81 X Z 2 S 2
329
X Q 3 1 R 1 X Y 2 S 1
330
X Q 3 1 R 1 X Z 2 S 2
331
X Q 3 2 R 4 X Y 2 S 1
332
X Q 3 2 R 4 X Z 2 S 2
333
X Q 3 3 R 9 X Y 2 S 1
334
X Q 3 3 R 9 X Z 2 S 2
335
X Q 3 5 R 25 X Y 2 S 1
336
X Q 3 5 R 25 X Z 2 S 2
337
X Q 3 6 R 36 X Y 2 S 1
338
X Q 3 6 R 36 X Z 2 S 2
339
X Q 3 7 R 49 X Y 2 S 1
340
X Q 3 7 R 49 X Z 2 S 2
341
X Q 3 9 R 81 X Y 2 S 1
342
X Q 3 9 R 81 X Z 2 S 2
343
X Q 5 1 R 1 X Y 2 S 1
344
X Q 5 1 R 1 X Z 2 S 2
345
X Q 5 2 R 4 X Y 2 S 1
346
X Q 5 2 R 4 X Z 2 S 2
347
X Q 5 3 R 9 X Y 2 S 1
348
X Q 5 3 R 9 X Z 2 S 2
349
X Q 5 5 R 25 X Y 2 S 1
350
X Q 5 5 R 25 X Z 2 S 2
351
X Q 5 6 R 36 X Y 2 S 1
352
X Q 5 6 R 36 X Z 2 S 2
353
X Q 5 7 R 49 X Y 2 S 1
354
X Q 5 7 R 49 X Z 2 S 2
355
X Q 5 9 R 81 X Y 2 S 1
356
X Q 5 9 R 81 X Z 2 S 2
357
CREATE TABLE t4 (C1 CHAR(1) PRIMARY KEY, B1 BIT(1), B2 BIT(1) NOT NULL DEFAULT 0, C2 CHAR(1) NOT NULL DEFAULT 'A') ENGINE = 'MYISAM' ;
358
INSERT INTO t4 SET C1 = 1;
359
SELECT C1,HEX(B1),HEX(B2) FROM t4 ORDER BY C1;
362
SELECT C1,HEX(B1),HEX(B2) FROM t4 ORDER BY C1;
365
CREATE TABLE t7 (C1 INT PRIMARY KEY, C2 INT) ENGINE = 'MYISAM' ;
366
--- on slave: original values ---
367
INSERT INTO t7 VALUES (1,3), (2,6), (3,9);
368
SELECT * FROM t7 ORDER BY C1;
373
set @@global.slave_exec_mode= 'IDEMPOTENT';
374
--- on master: new values inserted ---
375
INSERT INTO t7 VALUES (1,2), (2,4), (3,6);
376
SELECT * FROM t7 ORDER BY C1;
381
set @@global.slave_exec_mode= default;
382
--- on slave: old values should be overwritten by replicated values ---
383
SELECT * FROM t7 ORDER BY C1;
389
CREATE TABLE t8 (a INT PRIMARY KEY, b INT UNIQUE, c INT UNIQUE) ENGINE = 'MYISAM' ;
390
INSERT INTO t8 VALUES (99,99,99);
391
INSERT INTO t8 VALUES (99,22,33);
392
ERROR 23000: Duplicate entry '99' for key 'PRIMARY'
393
INSERT INTO t8 VALUES (11,99,33);
394
ERROR 23000: Duplicate entry '99' for key 'b'
395
INSERT INTO t8 VALUES (11,22,99);
396
ERROR 23000: Duplicate entry '99' for key 'c'
397
SELECT * FROM t8 ORDER BY a;
401
SELECT * FROM t8 ORDER BY a;
404
INSERT INTO t8 VALUES (1,2,3), (2,4,6), (3,6,9);
405
SELECT * FROM t8 ORDER BY a;
411
set @@global.slave_exec_mode= 'IDEMPOTENT';
413
INSERT INTO t8 VALUES (2,4,8);
414
set @@global.slave_exec_mode= default;
416
SELECT * FROM t8 ORDER BY a;
422
**** Test for BUG#31552 ****
425
**** Resetting master and slave ****
431
INSERT INTO t1 VALUES ('K','K'), ('L','L'), ('M','M');
433
set @@global.slave_exec_mode= 'IDEMPOTENT';
434
DELETE FROM t1 WHERE C1 = 'L';
436
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
438
set @@global.slave_exec_mode= default;
441
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
443
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;