include/master-slave.inc [connection master] **** On Slave **** STOP SLAVE; include/wait_for_slave_to_stop.inc **** On Master **** SET SESSION BINLOG_FORMAT=ROW; CREATE TABLE t1 (a INT, b INT) ENGINE=MyISAM; CREATE TABLE t2 (c INT, d INT) ENGINE=MyISAM; INSERT INTO t1 VALUES (1,1),(2,4),(3,9); INSERT INTO t2 VALUES (1,1),(2,8),(3,27); UPDATE t1,t2 SET b = d, d = b * 2 WHERE a = c; show binlog events from ; Log_name Pos Event_type Server_id End_log_pos Info master-bin.000001 # Query # # use `test`; CREATE TABLE t1 (a INT, b INT) ENGINE=MyISAM master-bin.000001 # Query # # use `test`; CREATE TABLE t2 (c INT, d INT) ENGINE=MyISAM master-bin.000001 # Query # # BEGIN master-bin.000001 # Table_map # # table_id: # (test.t1) master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F master-bin.000001 # Query # # COMMIT master-bin.000001 # Query # # BEGIN master-bin.000001 # Table_map # # table_id: # (test.t2) master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F master-bin.000001 # Query # # COMMIT master-bin.000001 # Query # # BEGIN master-bin.000001 # Table_map # # table_id: # (test.t1) master-bin.000001 # Table_map # # table_id: # (test.t2) master-bin.000001 # Update_rows # # table_id: # master-bin.000001 # Update_rows # # table_id: # flags: STMT_END_F master-bin.000001 # Query # # COMMIT SELECT * FROM t1; a b 1 1 2 8 3 27 SELECT * FROM t2; c d 1 2 2 8 3 18 **** On Slave **** START SLAVE UNTIL MASTER_LOG_FILE='master-bin.000001', MASTER_LOG_POS=MASTER_LOG_POS; include/wait_for_slave_sql_to_stop.inc include/check_slave_param.inc [Exec_Master_Log_Pos] include/check_slave_no_error.inc SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; START SLAVE; include/wait_for_slave_to_start.inc SELECT * FROM t1; a b 1 1 2 4 3 9 SELECT * FROM t2; c d 1 1 2 8 3 27 STOP SLAVE; include/wait_for_slave_to_stop.inc RESET SLAVE; RESET MASTER; SET SESSION BINLOG_FORMAT=STATEMENT; SET @foo = 12; INSERT INTO t1 VALUES(@foo, 2*@foo); show binlog events from ; Log_name Pos Event_type Server_id End_log_pos Info master-bin.000001 # Query # # BEGIN master-bin.000001 # User var # # @`foo`=12 master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES(@foo, 2*@foo) master-bin.000001 # Query # # COMMIT START SLAVE UNTIL MASTER_LOG_FILE='master-bin.000001', MASTER_LOG_POS=MASTER_LOG_POS; include/wait_for_slave_sql_to_stop.inc SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; START SLAVE; include/wait_for_slave_to_start.inc **** On Master **** DROP TABLE t1, t2; SET SESSION BINLOG_FORMAT=ROW; SET AUTOCOMMIT=0; CREATE TABLE t1 (a INT, b VARCHAR(20)) ENGINE=myisam; CREATE TABLE t2 (a INT, b VARCHAR(20)) ENGINE=myisam; CREATE TABLE t3 (a INT, b VARCHAR(20)) ENGINE=myisam; INSERT INTO t1 VALUES (1,'master/slave'); INSERT INTO t2 VALUES (1,'master/slave'); INSERT INTO t3 VALUES (1,'master/slave'); CREATE TRIGGER tr1 AFTER UPDATE on t1 FOR EACH ROW BEGIN INSERT INTO t2 VALUES (NEW.a,NEW.b); DELETE FROM t2 WHERE a < NEW.a; END| CREATE TRIGGER tr2 AFTER INSERT on t2 FOR EACH ROW BEGIN UPDATE t3 SET a =2, b = 'master only'; END| **** On Slave **** include/stop_slave.inc **** On Master **** UPDATE t1 SET a = 2, b = 'master only' WHERE a = 1; DROP TRIGGER tr1; DROP TRIGGER tr2; INSERT INTO t1 VALUES (3,'master/slave'); INSERT INTO t2 VALUES (3,'master/slave'); INSERT INTO t3 VALUES (3,'master/slave'); COMMIT; SELECT * FROM t1 ORDER BY a; a b 2 master only 3 master/slave SELECT * FROM t2 ORDER BY a; a b 2 master only 3 master/slave SELECT * FROM t3 ORDER BY a; a b 2 master only 3 master/slave *** On Slave *** SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; include/start_slave.inc SELECT * FROM t1 ORDER BY a; a b 1 master/slave 3 master/slave SELECT * FROM t2 ORDER BY a; a b 1 master/slave 3 master/slave SELECT * FROM t3 ORDER BY a; a b 1 master/slave 3 master/slave DROP TABLE t1, t2, t3; **** Case 2: Row binlog format and transactional tables **** *** On Master *** CREATE TABLE t4 (a INT, b VARCHAR(20)) ENGINE=innodb; CREATE TABLE t5 (a INT, b VARCHAR(20)) ENGINE=innodb; CREATE TABLE t6 (a INT, b VARCHAR(20)) ENGINE=innodb; **** On Slave **** include/stop_slave.inc *** On Master *** BEGIN; INSERT INTO t4 VALUES (2, 'master only'); INSERT INTO t5 VALUES (2, 'master only'); INSERT INTO t6 VALUES (2, 'master only'); COMMIT; BEGIN; INSERT INTO t4 VALUES (3, 'master/slave'); INSERT INTO t5 VALUES (3, 'master/slave'); INSERT INTO t6 VALUES (3, 'master/slave'); COMMIT; SELECT * FROM t4 ORDER BY a; a b 2 master only 3 master/slave SELECT * FROM t5 ORDER BY a; a b 2 master only 3 master/slave SELECT * FROM t6 ORDER BY a; a b 2 master only 3 master/slave *** On Slave *** SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; include/start_slave.inc SELECT * FROM t4 ORDER BY a; a b 3 master/slave SELECT * FROM t5 ORDER BY a; a b 3 master/slave SELECT * FROM t6 ORDER BY a; a b 3 master/slave **** On Slave **** include/stop_slave.inc *** On Master *** BEGIN; INSERT INTO t4 VALUES (6, 'master only'); INSERT INTO t5 VALUES (6, 'master only'); INSERT INTO t6 VALUES (6, 'master only'); COMMIT; BEGIN; INSERT INTO t4 VALUES (7, 'master only'); INSERT INTO t5 VALUES (7, 'master only'); INSERT INTO t6 VALUES (7, 'master only'); COMMIT; SELECT * FROM t4 ORDER BY a; a b 2 master only 3 master/slave 6 master only 7 master only SELECT * FROM t5 ORDER BY a; a b 2 master only 3 master/slave 6 master only 7 master only SELECT * FROM t6 ORDER BY a; a b 2 master only 3 master/slave 6 master only 7 master only *** On Slave *** SET GLOBAL SQL_SLAVE_SKIP_COUNTER=10; include/start_slave.inc SELECT * FROM t4 ORDER BY a; a b 3 master/slave SELECT * FROM t5 ORDER BY a; a b 3 master/slave SELECT * FROM t6 ORDER BY a; a b 3 master/slave include/stop_slave.inc SET AUTOCOMMIT=0; INSERT INTO t4 VALUES (4, 'master only'); INSERT INTO t5 VALUES (4, 'master only'); INSERT INTO t6 VALUES (4, 'master only'); COMMIT; INSERT INTO t4 VALUES (5, 'master/slave'); INSERT INTO t5 VALUES (5, 'master/slave'); INSERT INTO t6 VALUES (5, 'master/slave'); COMMIT; SELECT * FROM t4 ORDER BY a; a b 2 master only 3 master/slave 4 master only 5 master/slave 6 master only 7 master only SELECT * FROM t5 ORDER BY a; a b 2 master only 3 master/slave 4 master only 5 master/slave 6 master only 7 master only SELECT * FROM t6 ORDER BY a; a b 2 master only 3 master/slave 4 master only 5 master/slave 6 master only 7 master only *** On Slave *** SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; include/start_slave.inc SELECT * FROM t4 ORDER BY a; a b 3 master/slave 5 master/slave SELECT * FROM t5 ORDER BY a; a b 3 master/slave 5 master/slave SELECT * FROM t6 ORDER BY a; a b 3 master/slave 5 master/slave DROP TABLE t4, t5, t6; **** Case 3: Statement logging format and LOAD DATA with non-transactional table **** *** On Master *** CREATE TABLE t10 (a INT, b VARCHAR(20)) ENGINE=myisam; *** On Slave *** include/stop_slave.inc *** On Master *** SET SESSION BINLOG_FORMAT=STATEMENT; LOAD DATA INFILE 'MYSQLTEST_VARDIR/std_data/rpl_bug28618.dat' INTO TABLE t10 FIELDS TERMINATED BY '|'; SELECT * FROM t10 ORDER BY a; a b 1 master only 2 master only 3 master only *** On Slave *** SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1; include/start_slave.inc SELECT * FROM t10 ORDER BY a; a b DROP TABLE t10; include/rpl_end.inc