# ==== Purpose ==== # # Verify that INSERT DELAYED in mixed or row mode writes events to the # binlog, and that AUTO_INCREMENT works correctly. # # ==== Method ==== # # Insert both single and multiple rows into an autoincrement column, # both with specified value and with NULL. # # With INSERT DELAYED, the rows do not show up in the table # immediately, so we must do source include/wait_until_rows_count.inc # between any two INSERT DELAYED statements. Moreover, if mixed or # row-based logging is used, there is also a delay between when rows # show up in the table and when they show up in the binlog. To ensure # that the rows show up in the binlog, we call FLUSH TABLES, which # waits until the delayed_insert thread has finished. # # We cannot read the binlog after executing INSERT DELAYED statements # that insert multiple rows, because that is nondeterministic. More # precisely, rows may be written in batches to the binlog, where each # batch has one Table_map_log_event and one or more # Write_rows_log_event. The number of rows included in each batch is # nondeterministic. # # ==== Related bugs ==== # # BUG#20627: INSERT DELAYED does not honour auto_increment_* variables # Bug in this test: BUG#38068: binlog_stm_binlog fails sporadically in pushbuild create table t1 (a int not null auto_increment, primary key (a)) engine=myisam; let $table=t1; let $count=0; insert /* before delayed */ delayed /* after delayed */ into t1 values (207); inc $count; --source include/wait_until_rows_count.inc insert /*! delayed */ into t1 values (null); inc $count; --source include/wait_until_rows_count.inc insert delayed into t1 values (300); inc $count; --source include/wait_until_rows_count.inc # It is not enough to wait until all rows have been inserted into the # table. FLUSH TABLES ensures that they are in the binlog too. See # comment above. FLUSH TABLES; source include/show_binlog_events.inc; RESET MASTER; insert /* before delayed */ delayed /* after delayed */ into t1 values (null),(null),(null),(null); inc $count; inc $count; inc $count; inc $count; --source include/wait_until_rows_count.inc insert /*! delayed */ into t1 values (null),(null),(400),(null); inc $count; inc $count; inc $count; inc $count; --source include/wait_until_rows_count.inc if (`SELECT @@SESSION.BINLOG_FORMAT = 'STATEMENT'`) { FLUSH TABLES; source include/show_binlog_events.inc; } select * from t1; drop table t1;
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
binlog.test | File | 10.68 KB | 0644 |
|
binlog_cache_stat.test | File | 13.09 KB | 0644 |
|
binlog_implicit_commit.inc | File | 1.6 KB | 0644 |
|
binlog_innodb.inc | File | 3.9 KB | 0644 |
|
binlog_insert_delayed.test | File | 2.38 KB | 0644 |
|
binlog_mysqlbinlog_fill.inc | File | 1.76 KB | 0644 |
|
binlog_mysqlbinlog_row.inc | File | 13.06 KB | 0644 |
|
binlog_mysqlbinlog_start_stop.inc | File | 1.81 KB | 0644 |
|
binlog_truncate.test | File | 1.6 KB | 0644 |
|
blackhole.test | File | 5.85 KB | 0644 |
|
ctype_cp932.test | File | 27.76 KB | 0644 |
|
ctype_cp932_binlog.test | File | 1.25 KB | 0644 |
|
ctype_ucs_binlog.test | File | 938 B | 0644 |
|
database.test | File | 2.57 KB | 0644 |
|
drop_table.test | File | 547 B | 0644 |
|
drop_temp_table.test | File | 4.84 KB | 0644 |
|
implicit.test | File | 567 B | 0644 |
|
insert_select-binlog.test | File | 1.03 KB | 0644 |
|
mix_innodb_myisam_binlog.test | File | 15.43 KB | 0644 |
|
mix_innodb_myisam_side_effects.test | File | 6.47 KB | 0644 |
|
mysqlbinlog_row_engine.inc | File | 46.03 KB | 0644 |
|
mysqlbinlog_start_stop_1.inc | File | 1.71 KB | 0644 |
|
mysqlbinlog_start_stop_2.inc | File | 1.27 KB | 0644 |
|