# mysqlbinlog_trans.test # # Show that mysqlbinlog work correctly with transactions. # #--source include/have_myisam.inc --let $engine_type_nontrans= MyISAM --source include/have_innodb.inc --let $engine_type= InnoDB # # The test case would also work with statement based or mixed mode logging. # But this would require different result files. To handle this with the # current test suite, new main test cases are required. # --source include/have_binlog_format_row.inc --source include/have_log_bin.inc --echo # --echo # Preparatory cleanup. --echo # --disable_warnings DROP TABLE IF EXISTS t1, t2; --enable_warnings --echo # --echo # We need a fixed timestamp to avoid varying results. --echo # SET timestamp=1000000000; --echo # --echo # Delete all existing binary logs. --echo # RESET MASTER; --echo # --echo # Create test tables. --echo # eval CREATE TABLE t1 ( c1 INT, c2 VARCHAR(20) ) ENGINE=$engine_type DEFAULT CHARSET latin1; eval CREATE TABLE t2 ( c1 INT, c2 VARCHAR(20) ) ENGINE=$engine_type_nontrans DEFAULT CHARSET latin1; --echo # --echo # Start transaction #1, transactional table only, commit. --echo # START TRANSACTION; --echo # --echo # Do some statements. --echo # INSERT INTO t1 VALUES (1,'varchar-1'), (2,'varchar-2'), (3,'varchar-3'); UPDATE t1 SET c1 = c1 + 10; DELETE FROM t1 WHERE c1 = 12; --echo # --echo # Commit transaction. --echo # COMMIT; SELECT * FROM t1; TRUNCATE TABLE t1; --echo # --echo # Start transaction #2, transactional table only, rollback. --echo # START TRANSACTION; --echo # --echo # Do some statements. --echo # INSERT INTO t1 VALUES (1,'varchar-1'), (2,'varchar-2'), (3,'varchar-3'); UPDATE t1 SET c1 = c1 + 10; DELETE FROM t1 WHERE c1 = 12; --echo # --echo # Rollback transaction. --echo # ROLLBACK; SELECT * FROM t1; TRUNCATE TABLE t1; --echo # --echo # Start transaction #3, both tables, commit. --echo # START TRANSACTION; --echo # --echo # Do some statements on the transactional table. --echo # INSERT INTO t1 VALUES (1,'varchar-1'), (2,'varchar-2'), (3,'varchar-3'); UPDATE t1 SET c1 = c1 + 10; DELETE FROM t1 WHERE c1 = 12; --echo # --echo # Do some statements on the non-transactional table. --echo # INSERT INTO t2 VALUES (1,'varchar-1'), (2,'varchar-2'), (3,'varchar-3'); UPDATE t2 SET c1 = c1 + 10; DELETE FROM t2 WHERE c1 = 12; --echo # --echo # Commit transaction. --echo # COMMIT; SELECT * FROM t1; SELECT * FROM t2; TRUNCATE TABLE t1; TRUNCATE TABLE t2; --echo # --echo # Start transaction #4, both tables, rollback. --echo # START TRANSACTION; --echo # --echo # Do some statements on the transactional table. --echo # INSERT INTO t1 VALUES (1,'varchar-1'), (2,'varchar-2'), (3,'varchar-3'); UPDATE t1 SET c1 = c1 + 10; DELETE FROM t1 WHERE c1 = 12; --echo # --echo # Do some statements on the non-transactional table. --echo # INSERT INTO t2 VALUES (1,'varchar-1'), (2,'varchar-2'), (3,'varchar-3'); UPDATE t2 SET c1 = c1 + 10; DELETE FROM t2 WHERE c1 = 12; --echo # --echo # Rollback transaction. --echo # ROLLBACK; SELECT * FROM t1; SELECT * FROM t2; TRUNCATE TABLE t1; TRUNCATE TABLE t2; --echo # --echo # Flush all log buffers to the log file. --echo # FLUSH LOGS; --echo # --echo # Call mysqlbinlog to display the log file contents. --echo # let $MYSQLD_DATADIR= `select @@datadir`; --replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR --replace_regex /SQL_LOAD_MB-[0-9]-[0-9]/SQL_LOAD_MB-#-#/ /exec_time=[0-9]*/exec_time=#/ /end_log_pos [0-9]*/end_log_pos #/ /# at [0-9]*/# at #/ /Xid = [0-9]*/Xid = #/ /thread_id=[0-9]*/thread_id=#/ /table id [0-9]*/table id #/ /mapped to number [0-9]*/mapped to number #/ /server v [^ ]*/server v #.##.##/ --exec $MYSQL_BINLOG --base64-output=decode-rows -v -v $MYSQLTEST_VARDIR/log/master-bin.000001 --echo # --echo # Cleanup. --echo # DROP TABLE t1, t2;