mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
Replication changes for CREATE OR REPLACE TABLE
- CREATE TABLE is by default executed on the slave as CREATE OR REPLACE - DROP TABLE is by default executed on the slave as DROP TABLE IF NOT EXISTS This means that a slave will by default continue even if we try to create a table that existed on the slave (the table will be deleted and re-created) or if we try to drop a table that didn't exist on the slave. This should be safe as instead of having the slave stop because of an inconsistency between master and slave, it will fix the inconsistency. Those that would prefer to get a stopped slave instead for the above cases can set slave_ddl_exec_mode to STRICT. - Ensure that a CREATE OR REPLACE TABLE which dropped a table is replicated - DROP TABLE that generated an error on master is handled as an identical DROP TABLE on the slave (IF NOT EXISTS is not added in this case) - Added slave_ddl_exec_mode variable to decide how DDL's are replicated New logic for handling BEGIN GTID ... COMMIT from the binary log: - When we find a BEGIN GTID, we start a transaction and set OPTION_GTID_BEGIN - When we find COMMIT, we reset OPTION_GTID_BEGIN and execute the normal COMMIT code. - While OPTION_GTID_BEGIN is set: - We don't generate implict commits before or after statements - All tables are regarded as transactional tables in the binary log (to ensure things are executed exactly as on the master) - We reset OPTION_GTID_BEGIN also on rollback This will help ensuring that we don't get any sporadic commits (and thus new GTID's) on the slave and will help keep the GTID's between master and slave in sync. mysql-test/extra/rpl_tests/rpl_log.test: Added testing of mode slave_ddl_exec_mode=STRICT mysql-test/r/mysqld--help.result: New help messages mysql-test/suite/rpl/r/create_or_replace_mix.result: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/r/create_or_replace_row.result: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/r/create_or_replace_statement.result: Testing replication of create or replace mysql-test/suite/rpl/r/rpl_gtid_startpos.result: Test must be run in slave_ddl_exec_mode=STRICT as part of the test depends on that DROP TABLE should fail on slave. mysql-test/suite/rpl/r/rpl_row_log.result: Updated result mysql-test/suite/rpl/r/rpl_row_log_innodb.result: Updated result mysql-test/suite/rpl/r/rpl_row_show_relaylog_events.result: Updated result mysql-test/suite/rpl/r/rpl_stm_log.result: Updated result mysql-test/suite/rpl/r/rpl_stm_mix_show_relaylog_events.result: Updated result mysql-test/suite/rpl/r/rpl_temp_table_mix_row.result: Updated result mysql-test/suite/rpl/t/create_or_replace.inc: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/t/create_or_replace_mix.cnf: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/t/create_or_replace_mix.test: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/t/create_or_replace_row.cnf: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/t/create_or_replace_row.test: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/t/create_or_replace_statement.cnf: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/t/create_or_replace_statement.test: Testing of CREATE OR REPLACE TABLE with replication mysql-test/suite/rpl/t/rpl_gtid_startpos.test: Test must be run in slave_ddl_exec_mode=STRICT as part of the test depends on that DROP TABLE should fail on slave. mysql-test/suite/rpl/t/rpl_stm_log.test: Removed some lines mysql-test/suite/sys_vars/r/slave_ddl_exec_mode_basic.result: Testing of slave_ddl_exec_mode mysql-test/suite/sys_vars/t/slave_ddl_exec_mode_basic.test: Testing of slave_ddl_exec_mode sql/handler.cc: Regard all tables as transactional in commit if OPTION_GTID_BEGIN is set. This is to ensure that statments are not commited too early if non transactional tables are used. sql/log.cc: Regard all tables as transactional in commit if OPTION_GTID_BEGIN is set. Also treat 'direct' log events as transactional (to get them logged as they where on the master) sql/log_event.cc: Ensure that the new error from DROP TABLE when trying to drop a view is treated same as the old one. Store error code that slave expects in THD. Set OPTION_GTID_BEGIN if we find a BEGIN. Reset OPTION_GTID_BEGIN if we find a COMMIT. sql/mysqld.cc: Added slave_ddl_exec_mode_options sql/mysqld.h: Added slave_ddl_exec_mode_options sql/rpl_gtid.cc: Reset OPTION_GTID_BEGIN if we record a gtid (safety) sql/sql_class.cc: Regard all tables as transactional in commit if OPTION_GTID_BEGIN is set. sql/sql_class.h: Added to THD: log_current_statement and slave_expected_error sql/sql_insert.cc: Ensure that CREATE OR REPLACE is logged if table was deleted. Don't do implicit commit for CREATE if we are under OPTION_GTID_BEGIN sql/sql_parse.cc: Change CREATE TABLE -> CREATE OR REPLACE TABLE for slaves Change DROP TABLE -> DROP TABLE IF EXISTS for slaves CREATE TABLE doesn't force implicit commit in case of OPTION_GTID_BEGIN Don't do commits before or after any statement if OPTION_GTID_BEGIN was set. sql/sql_priv.h: Added OPTION_GTID_BEGIN sql/sql_show.cc: Enhanced store_create_info() to also be able to handle CREATE OR REPLACE sql/sql_show.h: Updated prototype sql/sql_table.cc: Ensure that CREATE OR REPLACE is logged if table was deleted. sql/sys_vars.cc: Added slave_ddl_exec_mode sql/transaction.cc: Added warning if we got a GTID under OPTION_GTID_BEGIN
This commit is contained in:
@ -18,8 +18,12 @@ start slave;
|
||||
--source include/wait_for_slave_to_start.inc
|
||||
|
||||
let $VERSION=`select version()`;
|
||||
|
||||
# Lets run this test in STRICT MODE (DROP TABLE is not DROP TABLE IF EXISTS)
|
||||
connection slave;
|
||||
set @save_slave_ddl_exec_mode=@@global.slave_ddl_exec_mode;
|
||||
set @@global.slave_ddl_exec_mode=STRICT;
|
||||
connection master;
|
||||
|
||||
eval create table t1(n int not null auto_increment primary key)ENGINE=$engine_type;
|
||||
insert into t1 values (NULL);
|
||||
drop table t1;
|
||||
@ -141,3 +145,5 @@ drop table t1;
|
||||
# End of 4.1 tests
|
||||
|
||||
sync_slave_with_master;
|
||||
set @@global.slave_ddl_exec_mode=@save_slave_ddl_exec_mode;
|
||||
connection master;
|
||||
|
@ -856,13 +856,22 @@ The following options may be given as the first argument:
|
||||
--skip-slave-start If set, slave is not autostarted.
|
||||
--slave-compressed-protocol
|
||||
Use compression on master/slave protocol
|
||||
--slave-ddl-exec-mode=name
|
||||
Modes for how replication events should be executed.
|
||||
Legal values are STRICT and IDEMPOTENT (default). In
|
||||
IDEMPOTENT mode, replication will not stop for DDL
|
||||
operations that are idempotent. This means that CREATE
|
||||
TABLE is treated CREATE TABLE OR REPLACE and DROP TABLE
|
||||
is threated as DROP TABLE IF EXISTS.
|
||||
--slave-exec-mode=name
|
||||
Modes for how replication events should be executed.
|
||||
Legal values are STRICT (default) and IDEMPOTENT. In
|
||||
IDEMPOTENT mode, replication will not stop for operations
|
||||
that are idempotent. In STRICT mode, replication will
|
||||
stop on any unexpected difference between the master and
|
||||
the slave
|
||||
that are idempotent. For example, in row based
|
||||
replication attempts to delete rows that doesn't exist
|
||||
will be ignored.In STRICT mode, replication will stop on
|
||||
any unexpected difference between the master and the
|
||||
slave
|
||||
--slave-load-tmpdir=name
|
||||
The location where the slave should put its temporary
|
||||
files when replicating a LOAD DATA INFILE command
|
||||
@ -1260,6 +1269,7 @@ skip-networking FALSE
|
||||
skip-show-database FALSE
|
||||
skip-slave-start FALSE
|
||||
slave-compressed-protocol FALSE
|
||||
slave-ddl-exec-mode IDEMPOTENT
|
||||
slave-exec-mode STRICT
|
||||
slave-max-allowed-packet 1073741824
|
||||
slave-net-timeout 3600
|
||||
|
162
mysql-test/suite/rpl/r/create_or_replace_mix.result
Normal file
162
mysql-test/suite/rpl/r/create_or_replace_mix.result
Normal file
@ -0,0 +1,162 @@
|
||||
include/rpl_init.inc [topology=1->2]
|
||||
create table t2 (a int) engine=myisam;
|
||||
insert into t2 values (0),(1),(2),(2);
|
||||
create temporary table t3 (a_in_temporary int) engine=myisam;
|
||||
#
|
||||
# Check how create table and create or replace table are logged
|
||||
#
|
||||
create table t1 (to_be_deleted int);
|
||||
CREATE TABLE t1 AS SELECT 1 AS f1;
|
||||
CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1;
|
||||
CREATE OR REPLACE table t1 like t2;
|
||||
CREATE OR REPLACE table t1 like t3;
|
||||
drop table t1;
|
||||
binlog from server 1
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t2 (a int) engine=myisam
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; insert into t2 values (0),(1),(2),(2)
|
||||
master-bin.000001 # Query # # COMMIT
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create temporary table t3 (a_in_temporary int) engine=myisam
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE TABLE t1 AS SELECT 1 AS f1
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t2
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t3
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t2 (a int) engine=myisam
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; insert into t2 values (0),(1),(2),(2)
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create temporary table t3 (a_in_temporary int) engine=myisam
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (to_be_deleted int)
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE TABLE t1 AS SELECT 1 AS f1
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t2
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t3
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
#
|
||||
# Ensure that also failed create_or_replace are logged
|
||||
#
|
||||
create table t1 (a int);
|
||||
create or replace table t1;
|
||||
ERROR 42000: A table must have at least 1 column
|
||||
drop table if exists t1;
|
||||
Warnings:
|
||||
Note 1051 Unknown table 'test.t1'
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
ERROR 23000: Duplicate entry '2' for key 'PRIMARY'
|
||||
create table t1 (a int);
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
ERROR 23000: Duplicate entry '2' for key 'PRIMARY'
|
||||
binlog from server 1
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create or replace table t1
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t1` (
|
||||
`a` int(11) NOT NULL,
|
||||
PRIMARY KEY (`a`)
|
||||
)
|
||||
master-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
master-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
master-bin.000001 # Query # # ROLLBACK
|
||||
show tables;
|
||||
Tables_in_test
|
||||
t1
|
||||
t2
|
||||
drop table if exists t1,t2;
|
||||
Warnings:
|
||||
Note 1051 Unknown table 'test.t1'
|
||||
#
|
||||
# Ensure that CREATE are run as CREATE OR REPLACE on slave
|
||||
#
|
||||
create table t1 (server_2_to_be_delete int);
|
||||
create table t1 (new_table int);
|
||||
show create table t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`new_table` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||
drop table t1;
|
||||
#
|
||||
# Ensure that DROP TABLE is run as DROP IF NOT EXISTS
|
||||
#
|
||||
create table t1 (server_1_ver_1 int);
|
||||
create table t4 (server_1_ver_2 int);
|
||||
drop table t1;
|
||||
drop table t1,t4;
|
||||
create table t1 (server_2_ver_2 int);
|
||||
show create table t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`server_2_ver_2` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1`,`t4` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (server_2_ver_2 int)
|
||||
drop table t1;
|
||||
#
|
||||
# Ensure that CREATE ... SELECT is recorded as one GTID on the slave
|
||||
#
|
||||
create table t1 (a int);
|
||||
insert into t1 values (0),(1),(2);
|
||||
create table t2 engine=myisam select * from t1;
|
||||
create or replace table t2 engine=innodb select * from t1;
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE TABLE `t2` (
|
||||
`a` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t2` (
|
||||
`a` int(11) DEFAULT NULL
|
||||
) ENGINE=InnoDB
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Xid # # COMMIT /* XID */
|
||||
drop table t1;
|
||||
drop table t2;
|
||||
include/rpl_end.inc
|
184
mysql-test/suite/rpl/r/create_or_replace_row.result
Normal file
184
mysql-test/suite/rpl/r/create_or_replace_row.result
Normal file
@ -0,0 +1,184 @@
|
||||
include/rpl_init.inc [topology=1->2]
|
||||
create table t2 (a int) engine=myisam;
|
||||
insert into t2 values (0),(1),(2),(2);
|
||||
create temporary table t3 (a_in_temporary int) engine=myisam;
|
||||
#
|
||||
# Check how create table and create or replace table are logged
|
||||
#
|
||||
create table t1 (to_be_deleted int);
|
||||
CREATE TABLE t1 AS SELECT 1 AS f1;
|
||||
CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1;
|
||||
CREATE OR REPLACE table t1 like t2;
|
||||
CREATE OR REPLACE table t1 like t3;
|
||||
drop table t1;
|
||||
binlog from server 1
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t2 (a int) engine=myisam
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||
master-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
master-bin.000001 # Query # # COMMIT
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE TABLE `t1` (
|
||||
`f1` int(1) NOT NULL DEFAULT '0'
|
||||
)
|
||||
master-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
master-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
master-bin.000001 # Query # # COMMIT
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t1` (
|
||||
`f1` int(1) NOT NULL DEFAULT '0'
|
||||
)
|
||||
master-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
master-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
master-bin.000001 # Query # # COMMIT
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t2
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t1` (
|
||||
`a_in_temporary` int(11) DEFAULT NULL
|
||||
)
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t2 (a int) engine=myisam
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (to_be_deleted int)
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE TABLE `t1` (
|
||||
`f1` int(1) NOT NULL DEFAULT '0'
|
||||
)
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t1` (
|
||||
`f1` int(1) NOT NULL DEFAULT '0'
|
||||
)
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t2
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t1` (
|
||||
`a_in_temporary` int(11) DEFAULT NULL
|
||||
)
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
#
|
||||
# Ensure that also failed create_or_replace are logged
|
||||
#
|
||||
create table t1 (a int);
|
||||
create or replace table t1;
|
||||
ERROR 42000: A table must have at least 1 column
|
||||
drop table if exists t1;
|
||||
Warnings:
|
||||
Note 1051 Unknown table 'test.t1'
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
ERROR 23000: Duplicate entry '2' for key 'PRIMARY'
|
||||
create table t1 (a int);
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
ERROR 23000: Duplicate entry '2' for key 'PRIMARY'
|
||||
binlog from server 1
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create or replace table t1
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t1` (
|
||||
`a` int(11) NOT NULL,
|
||||
PRIMARY KEY (`a`)
|
||||
)
|
||||
master-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
master-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
master-bin.000001 # Query # # ROLLBACK
|
||||
show tables;
|
||||
Tables_in_test
|
||||
t1
|
||||
t2
|
||||
drop table if exists t1,t2;
|
||||
Warnings:
|
||||
Note 1051 Unknown table 'test.t1'
|
||||
#
|
||||
# Ensure that CREATE are run as CREATE OR REPLACE on slave
|
||||
#
|
||||
create table t1 (server_2_to_be_delete int);
|
||||
create table t1 (new_table int);
|
||||
show create table t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`new_table` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||
drop table t1;
|
||||
#
|
||||
# Ensure that DROP TABLE is run as DROP IF NOT EXISTS
|
||||
#
|
||||
create table t1 (server_1_ver_1 int);
|
||||
create table t4 (server_1_ver_2 int);
|
||||
drop table t1;
|
||||
drop table t1,t4;
|
||||
create table t1 (server_2_ver_2 int);
|
||||
show create table t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`server_2_ver_2` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1`,`t4` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (server_2_ver_2 int)
|
||||
drop table t1;
|
||||
#
|
||||
# Ensure that CREATE ... SELECT is recorded as one GTID on the slave
|
||||
#
|
||||
create table t1 (a int);
|
||||
insert into t1 values (0),(1),(2);
|
||||
create table t2 engine=myisam select * from t1;
|
||||
create or replace table t2 engine=innodb select * from t1;
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE TABLE `t2` (
|
||||
`a` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE `t2` (
|
||||
`a` int(11) DEFAULT NULL
|
||||
) ENGINE=InnoDB
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t2)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
slave-bin.000001 # Xid # # COMMIT /* XID */
|
||||
drop table t1;
|
||||
drop table t2;
|
||||
include/rpl_end.inc
|
144
mysql-test/suite/rpl/r/create_or_replace_statement.result
Normal file
144
mysql-test/suite/rpl/r/create_or_replace_statement.result
Normal file
@ -0,0 +1,144 @@
|
||||
include/rpl_init.inc [topology=1->2]
|
||||
create table t2 (a int) engine=myisam;
|
||||
insert into t2 values (0),(1),(2),(2);
|
||||
create temporary table t3 (a_in_temporary int) engine=myisam;
|
||||
#
|
||||
# Check how create table and create or replace table are logged
|
||||
#
|
||||
create table t1 (to_be_deleted int);
|
||||
CREATE TABLE t1 AS SELECT 1 AS f1;
|
||||
CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1;
|
||||
CREATE OR REPLACE table t1 like t2;
|
||||
CREATE OR REPLACE table t1 like t3;
|
||||
drop table t1;
|
||||
binlog from server 1
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t2 (a int) engine=myisam
|
||||
master-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; insert into t2 values (0),(1),(2),(2)
|
||||
master-bin.000001 # Query # # COMMIT
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create temporary table t3 (a_in_temporary int) engine=myisam
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE TABLE t1 AS SELECT 1 AS f1
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t2
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t3
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t2 (a int) engine=myisam
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; insert into t2 values (0),(1),(2),(2)
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create temporary table t3 (a_in_temporary int) engine=myisam
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (to_be_deleted int)
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE TABLE t1 AS SELECT 1 AS f1
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t2
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; CREATE OR REPLACE table t1 like t3
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
#
|
||||
# Ensure that also failed create_or_replace are logged
|
||||
#
|
||||
create table t1 (a int);
|
||||
create or replace table t1;
|
||||
ERROR 42000: A table must have at least 1 column
|
||||
drop table if exists t1;
|
||||
Warnings:
|
||||
Note 1051 Unknown table 'test.t1'
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
ERROR 23000: Duplicate entry '2' for key 'PRIMARY'
|
||||
create table t1 (a int);
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
ERROR 23000: Duplicate entry '2' for key 'PRIMARY'
|
||||
binlog from server 1
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create or replace table t1
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
master-bin.000001 # Gtid # # GTID #-#-#
|
||||
master-bin.000001 # Query # # use `test`; create or replace table t1 (a int primary key) select a from t2
|
||||
show tables;
|
||||
Tables_in_test
|
||||
t2
|
||||
drop table if exists t1,t2;
|
||||
Warnings:
|
||||
Note 1051 Unknown table 'test.t1'
|
||||
#
|
||||
# Ensure that CREATE are run as CREATE OR REPLACE on slave
|
||||
#
|
||||
create table t1 (server_2_to_be_delete int);
|
||||
create table t1 (new_table int);
|
||||
show create table t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`new_table` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||
drop table t1;
|
||||
#
|
||||
# Ensure that DROP TABLE is run as DROP IF NOT EXISTS
|
||||
#
|
||||
create table t1 (server_1_ver_1 int);
|
||||
create table t4 (server_1_ver_2 int);
|
||||
drop table t1;
|
||||
drop table t1,t4;
|
||||
create table t1 (server_2_ver_2 int);
|
||||
show create table t1;
|
||||
Table Create Table
|
||||
t1 CREATE TABLE `t1` (
|
||||
`server_2_ver_2` int(11) DEFAULT NULL
|
||||
) ENGINE=MyISAM DEFAULT CHARSET=latin1
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t1`,`t4` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (server_2_ver_2 int)
|
||||
drop table t1;
|
||||
#
|
||||
# Ensure that CREATE ... SELECT is recorded as one GTID on the slave
|
||||
#
|
||||
create table t1 (a int);
|
||||
insert into t1 values (0),(1),(2);
|
||||
create table t2 engine=myisam select * from t1;
|
||||
create or replace table t2 engine=innodb select * from t1;
|
||||
binlog from server 2
|
||||
include/show_binlog_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t1 (a int)
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; insert into t1 values (0),(1),(2)
|
||||
slave-bin.000001 # Query # # COMMIT
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create table t2 engine=myisam select * from t1
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; create or replace table t2 engine=innodb select * from t1
|
||||
drop table t1;
|
||||
drop table t2;
|
||||
include/rpl_end.inc
|
@ -110,6 +110,8 @@ DROP TABLE t1;
|
||||
SET SQL_LOG_BIN=1;
|
||||
RESET SLAVE;
|
||||
SET GLOBAL gtid_slave_pos="";
|
||||
SET @save_slave_ddl_exec_mode=@@global.slave_ddl_exec_mode;
|
||||
SET GLOBAL slave_ddl_exec_mode=STRICT;
|
||||
include/start_slave.inc
|
||||
SELECT * FROM t1 ORDER BY a;
|
||||
a
|
||||
@ -225,4 +227,5 @@ a
|
||||
1
|
||||
2
|
||||
DROP TABLE t1;
|
||||
set @@global.slave_ddl_exec_mode=@save_slave_ddl_exec_mode;
|
||||
include/rpl_end.inc
|
||||
|
@ -6,6 +6,8 @@ reset master;
|
||||
reset slave;
|
||||
start slave;
|
||||
include/wait_for_slave_to_start.inc
|
||||
set @save_slave_ddl_exec_mode=@@global.slave_ddl_exec_mode;
|
||||
set @@global.slave_ddl_exec_mode=STRICT;
|
||||
create table t1(n int not null auto_increment primary key)ENGINE=MyISAM;
|
||||
insert into t1 values (NULL);
|
||||
drop table t1;
|
||||
@ -287,4 +289,5 @@ a b
|
||||
5 1
|
||||
6 1
|
||||
drop table t1;
|
||||
set @@global.slave_ddl_exec_mode=@save_slave_ddl_exec_mode;
|
||||
include/rpl_end.inc
|
||||
|
@ -6,6 +6,8 @@ reset master;
|
||||
reset slave;
|
||||
start slave;
|
||||
include/wait_for_slave_to_start.inc
|
||||
set @save_slave_ddl_exec_mode=@@global.slave_ddl_exec_mode;
|
||||
set @@global.slave_ddl_exec_mode=STRICT;
|
||||
create table t1(n int not null auto_increment primary key)ENGINE=InnoDB;
|
||||
insert into t1 values (NULL);
|
||||
drop table t1;
|
||||
@ -287,4 +289,5 @@ a b
|
||||
5 1
|
||||
6 1
|
||||
drop table t1;
|
||||
set @@global.slave_ddl_exec_mode=@save_slave_ddl_exec_mode;
|
||||
include/rpl_end.inc
|
||||
|
@ -172,7 +172,7 @@ include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000002 # Binlog_checkpoint # # slave-bin.000002
|
||||
slave-bin.000002 # Gtid # # GTID #-#-#
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
******** [slave] SHOW BINLOG EVENTS IN <FILE> LIMIT 2 ********
|
||||
include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
@ -181,7 +181,7 @@ slave-bin.000002 # Gtid # # GTID #-#-#
|
||||
******** [slave] SHOW BINLOG EVENTS IN <FILE> LIMIT 2,3 ********
|
||||
include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
******** [slave] SHOW BINLOG EVENTS ********
|
||||
include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
|
@ -6,6 +6,8 @@ reset master;
|
||||
reset slave;
|
||||
start slave;
|
||||
include/wait_for_slave_to_start.inc
|
||||
set @save_slave_ddl_exec_mode=@@global.slave_ddl_exec_mode;
|
||||
set @@global.slave_ddl_exec_mode=STRICT;
|
||||
create table t1(n int not null auto_increment primary key)ENGINE=MyISAM;
|
||||
insert into t1 values (NULL);
|
||||
drop table t1;
|
||||
@ -286,4 +288,5 @@ a b
|
||||
5 1
|
||||
6 1
|
||||
drop table t1;
|
||||
set @@global.slave_ddl_exec_mode=@save_slave_ddl_exec_mode;
|
||||
include/rpl_end.inc
|
||||
|
@ -154,7 +154,7 @@ include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000002 # Binlog_checkpoint # # slave-bin.000002
|
||||
slave-bin.000002 # Gtid # # GTID #-#-#
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
******** [slave] SHOW BINLOG EVENTS IN <FILE> LIMIT 2 ********
|
||||
include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
@ -163,7 +163,7 @@ slave-bin.000002 # Gtid # # GTID #-#-#
|
||||
******** [slave] SHOW BINLOG EVENTS IN <FILE> LIMIT 2,3 ********
|
||||
include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE `t1` /* generated by server */
|
||||
slave-bin.000002 # Query # # use `test`; DROP TABLE IF EXISTS `t1` /* generated by server */
|
||||
******** [slave] SHOW BINLOG EVENTS ********
|
||||
include/show_events.inc
|
||||
Log_name Pos Event_type Server_id End_log_pos Info
|
||||
|
@ -62,7 +62,7 @@ slave-bin.000001 # Query # # use `test`; ALTER TABLE t1_tmp ADD COLUMN b INT
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # DROP TEMPORARY TABLE IF EXISTS `test`.`t1_tmp` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE `t2` /* generated by server */
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t2` /* generated by server */
|
||||
slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Table_map # # table_id: # (test.t1)
|
||||
slave-bin.000001 # Write_rows_v1 # # table_id: # flags: STMT_END_F
|
||||
@ -73,7 +73,7 @@ slave-bin.000001 # Gtid # # BEGIN GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (2)
|
||||
slave-bin.000001 # Xid # # COMMIT /* XID */
|
||||
slave-bin.000001 # Gtid # # GTID #-#-#
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE `t3`,`t1` /* generated by server */
|
||||
slave-bin.000001 # Query # # use `test`; DROP TABLE IF EXISTS `t3`,`t1` /* generated by server */
|
||||
|
||||
# Bug#55478 Row events wrongly apply on the temporary table of the same name
|
||||
# ==========================================================================
|
||||
|
137
mysql-test/suite/rpl/t/create_or_replace.inc
Normal file
137
mysql-test/suite/rpl/t/create_or_replace.inc
Normal file
@ -0,0 +1,137 @@
|
||||
# Test CREATE OR REPLACE TABLE in replication
|
||||
--source include/have_innodb.inc
|
||||
|
||||
--let $rpl_topology=1->2
|
||||
--source include/rpl_init.inc
|
||||
|
||||
# Create help tables
|
||||
create table t2 (a int) engine=myisam;
|
||||
insert into t2 values (0),(1),(2),(2);
|
||||
create temporary table t3 (a_in_temporary int) engine=myisam;
|
||||
|
||||
--echo #
|
||||
--echo # Check how create table and create or replace table are logged
|
||||
--echo #
|
||||
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
create table t1 (to_be_deleted int);
|
||||
|
||||
connection server_1;
|
||||
CREATE TABLE t1 AS SELECT 1 AS f1;
|
||||
CREATE OR REPLACE TABLE t1 AS SELECT 2 AS f1;
|
||||
CREATE OR REPLACE table t1 like t2;
|
||||
CREATE OR REPLACE table t1 like t3;
|
||||
drop table t1;
|
||||
|
||||
--echo binlog from server 1
|
||||
--source include/show_binlog_events.inc
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
--echo binlog from server 2
|
||||
--source include/show_binlog_events.inc
|
||||
|
||||
connection server_1;
|
||||
|
||||
--echo #
|
||||
--echo # Ensure that also failed create_or_replace are logged
|
||||
--echo #
|
||||
|
||||
--let $binlog_start=query_get_value(SHOW MASTER STATUS, Position, 1)
|
||||
|
||||
create table t1 (a int);
|
||||
--error ER_TABLE_MUST_HAVE_COLUMNS
|
||||
create or replace table t1;
|
||||
drop table if exists t1;
|
||||
# The following is not logged as t1 does not exists;
|
||||
--error ER_DUP_ENTRY
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
|
||||
create table t1 (a int);
|
||||
# This should be logged as we will delete t1
|
||||
--error ER_DUP_ENTRY
|
||||
create or replace table t1 (a int primary key) select a from t2;
|
||||
|
||||
--echo binlog from server 1
|
||||
--source include/show_binlog_events.inc
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
show tables;
|
||||
connection server_1;
|
||||
|
||||
drop table if exists t1,t2;
|
||||
|
||||
--echo #
|
||||
--echo # Ensure that CREATE are run as CREATE OR REPLACE on slave
|
||||
--echo #
|
||||
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
create table t1 (server_2_to_be_delete int);
|
||||
connection server_1;
|
||||
create table t1 (new_table int);
|
||||
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
|
||||
show create table t1;
|
||||
connection server_1;
|
||||
drop table t1;
|
||||
|
||||
--echo #
|
||||
--echo # Ensure that DROP TABLE is run as DROP IF NOT EXISTS
|
||||
--echo #
|
||||
|
||||
create table t1 (server_1_ver_1 int);
|
||||
create table t4 (server_1_ver_2 int);
|
||||
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
--let $binlog_start=query_get_value(SHOW MASTER STATUS, Position, 1)
|
||||
|
||||
# Drop the table on the slave
|
||||
drop table t1;
|
||||
connection server_1;
|
||||
drop table t1,t4;
|
||||
create table t1 (server_2_ver_2 int);
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
show create table t1;
|
||||
--echo binlog from server 2
|
||||
--source include/show_binlog_events.inc
|
||||
connection server_1;
|
||||
drop table t1;
|
||||
|
||||
--echo #
|
||||
--echo # Ensure that CREATE ... SELECT is recorded as one GTID on the slave
|
||||
--echo #
|
||||
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
--let $binlog_start=query_get_value(SHOW MASTER STATUS, Position, 1)
|
||||
connection server_1;
|
||||
|
||||
create table t1 (a int);
|
||||
insert into t1 values (0),(1),(2);
|
||||
create table t2 engine=myisam select * from t1;
|
||||
create or replace table t2 engine=innodb select * from t1;
|
||||
save_master_pos;
|
||||
connection server_2;
|
||||
sync_with_master;
|
||||
--echo binlog from server 2
|
||||
--source include/show_binlog_events.inc
|
||||
connection server_1;
|
||||
drop table t1;
|
||||
|
||||
# Clean up
|
||||
drop table t2;
|
||||
|
||||
--source include/rpl_end.inc
|
9
mysql-test/suite/rpl/t/create_or_replace_mix.cnf
Normal file
9
mysql-test/suite/rpl/t/create_or_replace_mix.cnf
Normal file
@ -0,0 +1,9 @@
|
||||
!include suite/rpl/my.cnf
|
||||
|
||||
[mysqld.1]
|
||||
log-slave-updates
|
||||
loose-innodb
|
||||
|
||||
[mysqld.2]
|
||||
log-slave-updates
|
||||
loose-innodb
|
4
mysql-test/suite/rpl/t/create_or_replace_mix.test
Normal file
4
mysql-test/suite/rpl/t/create_or_replace_mix.test
Normal file
@ -0,0 +1,4 @@
|
||||
# Testing create or replace table in mixed mode.
|
||||
|
||||
--source include/have_binlog_format_mixed.inc
|
||||
--source create_or_replace.inc
|
9
mysql-test/suite/rpl/t/create_or_replace_row.cnf
Normal file
9
mysql-test/suite/rpl/t/create_or_replace_row.cnf
Normal file
@ -0,0 +1,9 @@
|
||||
!include suite/rpl/my.cnf
|
||||
|
||||
[mysqld.1]
|
||||
log-slave-updates
|
||||
loose-innodb
|
||||
|
||||
[mysqld.2]
|
||||
log-slave-updates
|
||||
loose-innodb
|
4
mysql-test/suite/rpl/t/create_or_replace_row.test
Normal file
4
mysql-test/suite/rpl/t/create_or_replace_row.test
Normal file
@ -0,0 +1,4 @@
|
||||
# Testing create or replace table in mixed mode.
|
||||
|
||||
--source include/have_binlog_format_row.inc
|
||||
--source create_or_replace.inc
|
9
mysql-test/suite/rpl/t/create_or_replace_statement.cnf
Normal file
9
mysql-test/suite/rpl/t/create_or_replace_statement.cnf
Normal file
@ -0,0 +1,9 @@
|
||||
!include suite/rpl/my.cnf
|
||||
|
||||
[mysqld.1]
|
||||
log-slave-updates
|
||||
loose-innodb
|
||||
|
||||
[mysqld.2]
|
||||
log-slave-updates
|
||||
loose-innodb
|
4
mysql-test/suite/rpl/t/create_or_replace_statement.test
Normal file
4
mysql-test/suite/rpl/t/create_or_replace_statement.test
Normal file
@ -0,0 +1,4 @@
|
||||
# Testing create or replace table in mixed mode.
|
||||
|
||||
--source include/have_binlog_format_statement.inc
|
||||
--source create_or_replace.inc
|
@ -165,7 +165,7 @@ SET GLOBAL gtid_slave_pos="";
|
||||
SELECT * FROM t1 ORDER BY a;
|
||||
|
||||
|
||||
# Same thing, but this time using SQL_LOG_BIN=0 to avoid polliting the
|
||||
# Same thing, but this time using SQL_LOG_BIN=0 to avoid polluting the
|
||||
# slave binlog.
|
||||
|
||||
--connection server_2
|
||||
@ -175,6 +175,9 @@ DROP TABLE t1;
|
||||
SET SQL_LOG_BIN=1;
|
||||
RESET SLAVE;
|
||||
SET GLOBAL gtid_slave_pos="";
|
||||
# Ensure that the slave fails because of missing table to be dropped
|
||||
SET @save_slave_ddl_exec_mode=@@global.slave_ddl_exec_mode;
|
||||
SET GLOBAL slave_ddl_exec_mode=STRICT;
|
||||
|
||||
--source include/start_slave.inc
|
||||
--sync_with_master
|
||||
@ -349,6 +352,7 @@ SELECT * FROM t1 ORDER BY a;
|
||||
# Clean up.
|
||||
--connection server_1
|
||||
DROP TABLE t1;
|
||||
|
||||
--connection server_2
|
||||
set @@global.slave_ddl_exec_mode=@save_slave_ddl_exec_mode;
|
||||
|
||||
--source include/rpl_end.inc
|
||||
|
@ -4,7 +4,5 @@
|
||||
let $engine_type=MyISAM;
|
||||
-- source extra/rpl_tests/rpl_log.test
|
||||
|
||||
|
||||
# End of 4.1 tests
|
||||
# Adding comment for force manual merge 5.0 -> wl1012: Delete me
|
||||
--source include/rpl_end.inc
|
||||
|
39
mysql-test/suite/sys_vars/r/slave_ddl_exec_mode_basic.result
Normal file
39
mysql-test/suite/sys_vars/r/slave_ddl_exec_mode_basic.result
Normal file
@ -0,0 +1,39 @@
|
||||
SET @start_value = @@global.slave_ddl_exec_mode;
|
||||
SELECT @@global.slave_ddl_exec_mode;
|
||||
@@global.slave_ddl_exec_mode
|
||||
IDEMPOTENT
|
||||
SELECT @@slave_ddl_exec_mode = @@GLOBAL.slave_ddl_exec_mode;
|
||||
@@slave_ddl_exec_mode = @@GLOBAL.slave_ddl_exec_mode
|
||||
1
|
||||
1 Expected
|
||||
SELECT COUNT(@@slave_ddl_exec_mode);
|
||||
COUNT(@@slave_ddl_exec_mode)
|
||||
1
|
||||
1 Expected
|
||||
SELECT COUNT(@@local.slave_ddl_exec_mode);
|
||||
ERROR HY000: Variable 'slave_ddl_exec_mode' is a GLOBAL variable
|
||||
Expected error 'Variable is a GLOBAL variable'
|
||||
SELECT COUNT(@@SESSION.slave_ddl_exec_mode);
|
||||
ERROR HY000: Variable 'slave_ddl_exec_mode' is a GLOBAL variable
|
||||
Expected error 'Variable is a GLOBAL variable'
|
||||
SELECT COUNT(@@GLOBAL.slave_ddl_exec_mode);
|
||||
COUNT(@@GLOBAL.slave_ddl_exec_mode)
|
||||
1
|
||||
1 Expected
|
||||
SELECT slave_ddl_exec_mode = @@SESSION.version;
|
||||
ERROR 42S22: Unknown column 'slave_ddl_exec_mode' in 'field list'
|
||||
Expected error 'Readonly variable'
|
||||
SET @@GLOBAL.slave_ddl_exec_mode=STRICT;
|
||||
SELECT @@GLOBAL.slave_ddl_exec_mode;
|
||||
@@GLOBAL.slave_ddl_exec_mode
|
||||
STRICT
|
||||
SET @@GLOBAL.slave_ddl_exec_mode=IDEMPOTENT;
|
||||
SELECT @@GLOBAL.slave_ddl_exec_mode;
|
||||
@@GLOBAL.slave_ddl_exec_mode
|
||||
IDEMPOTENT
|
||||
SET @@GLOBAL.slave_ddl_exec_mode=XXX;
|
||||
ERROR 42000: Variable 'slave_ddl_exec_mode' can't be set to the value of 'XXX'
|
||||
SELECT @@GLOBAL.slave_ddl_exec_mode;
|
||||
@@GLOBAL.slave_ddl_exec_mode
|
||||
IDEMPOTENT
|
||||
SET @@global.slave_ddl_exec_mode= @start_value;
|
67
mysql-test/suite/sys_vars/t/slave_ddl_exec_mode_basic.test
Normal file
67
mysql-test/suite/sys_vars/t/slave_ddl_exec_mode_basic.test
Normal file
@ -0,0 +1,67 @@
|
||||
############## mysql-test\t\slave_ddl_exec_mode_basic.test ####################
|
||||
# #
|
||||
# Variable Name: slave_ddl_exec_mode #
|
||||
# Scope: GLOBAL & SESSION #
|
||||
# Access Type: Dynamic #
|
||||
# Data Type: Numeric #
|
||||
# Default Value: 1 #
|
||||
# Range: 1 - 65536 #
|
||||
# #
|
||||
# #
|
||||
# Description: Test Cases of Dynamic System Variable slave_ddl_exec_mode #
|
||||
# that checks the behavior of this variable in the following ways#
|
||||
# * Default Value #
|
||||
# * Valid & Invalid values #
|
||||
# * Scope & Access method #
|
||||
# * Data Integrity #
|
||||
# #
|
||||
###############################################################################
|
||||
|
||||
--source include/not_embedded.inc
|
||||
--source include/load_sysvars.inc
|
||||
|
||||
########################################################################
|
||||
# START OF slave_ddl_exec_mode TESTS #
|
||||
########################################################################
|
||||
|
||||
SET @start_value = @@global.slave_ddl_exec_mode;
|
||||
|
||||
SELECT @@global.slave_ddl_exec_mode;
|
||||
|
||||
SELECT @@slave_ddl_exec_mode = @@GLOBAL.slave_ddl_exec_mode;
|
||||
--echo 1 Expected
|
||||
|
||||
SELECT COUNT(@@slave_ddl_exec_mode);
|
||||
--echo 1 Expected
|
||||
|
||||
--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
|
||||
SELECT COUNT(@@local.slave_ddl_exec_mode);
|
||||
--echo Expected error 'Variable is a GLOBAL variable'
|
||||
|
||||
--Error ER_INCORRECT_GLOBAL_LOCAL_VAR
|
||||
SELECT COUNT(@@SESSION.slave_ddl_exec_mode);
|
||||
--echo Expected error 'Variable is a GLOBAL variable'
|
||||
|
||||
SELECT COUNT(@@GLOBAL.slave_ddl_exec_mode);
|
||||
--echo 1 Expected
|
||||
|
||||
--Error ER_BAD_FIELD_ERROR
|
||||
SELECT slave_ddl_exec_mode = @@SESSION.version;
|
||||
--echo Expected error 'Readonly variable'
|
||||
|
||||
|
||||
SET @@GLOBAL.slave_ddl_exec_mode=STRICT;
|
||||
SELECT @@GLOBAL.slave_ddl_exec_mode;
|
||||
|
||||
SET @@GLOBAL.slave_ddl_exec_mode=IDEMPOTENT;
|
||||
SELECT @@GLOBAL.slave_ddl_exec_mode;
|
||||
|
||||
--error ER_WRONG_VALUE_FOR_VAR
|
||||
SET @@GLOBAL.slave_ddl_exec_mode=XXX;
|
||||
SELECT @@GLOBAL.slave_ddl_exec_mode;
|
||||
|
||||
SET @@global.slave_ddl_exec_mode= @start_value;
|
||||
|
||||
########################################################################
|
||||
# END OF slave_ddl_exec_mode TESTS #
|
||||
########################################################################
|
Reference in New Issue
Block a user