Browse Source
			
			
			BUG#45574 CREATE IF NOT EXISTS is not binlogged if the object exists
			
				
		BUG#45574 CREATE IF NOT EXISTS is not binlogged if the object exists
	
		
	
			
				There is an inconsistency with DROP DATABASE|TABLE|EVENT IF EXISTS and CREATE DATABASE|TABLE|EVENT IF NOT EXISTS. DROP IF EXISTS statements are binlogged even if either the DB, TABLE or EVENT does not exist. In contrast, Only the CREATE EVENT IF NOT EXISTS is binlogged when the EVENT exists. This patch fixes the following cases for all the replication formats: CREATE DATABASE IF NOT EXISTS. CREATE TABLE IF NOT EXISTS, CREATE TABLE IF NOT EXISTS ... LIKE, CREAET TABLE IF NOT EXISTS ... SELECT. sql/sql_insert.cc: Part of the code was moved from the create_table_from_items to select_create::prepare. When replication is row based, CREATE TABLE IF NOT EXISTS.. SELECT is binlogged if the table exists.pull/374/head
				 7 changed files with 255 additions and 53 deletions
			
			
		- 
					33mysql-test/suite/rpl/r/rpl_create_if_not_exists.result
- 
					22mysql-test/suite/rpl/r/rpl_create_tmp_table_if_not_exists.result
- 
					70mysql-test/suite/rpl/t/rpl_create_if_not_exists.test
- 
					41mysql-test/suite/rpl/t/rpl_create_tmp_table_if_not_exists.test
- 
					7sql/sql_db.cc
- 
					52sql/sql_insert.cc
- 
					83sql/sql_table.cc
| @ -0,0 +1,33 @@ | |||
| stop slave; | |||
| drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9; | |||
| reset master; | |||
| reset slave; | |||
| drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9; | |||
| start slave; | |||
| DROP DATABASE IF EXISTS mysqltest; | |||
| CREATE DATABASE IF NOT EXISTS mysqltest; | |||
| USE mysqltest; | |||
| CREATE TABLE IF NOT EXISTS t(c1 int); | |||
| CREATE TABLE IF NOT EXISTS t1 LIKE t; | |||
| CREATE TABLE IF NOT EXISTS t2 SELECT * FROM t; | |||
| CREATE EVENT IF NOT EXISTS e  | |||
| ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR  | |||
| DO SELECT now(); | |||
| DROP DATABASE mysqltest; | |||
| CREATE DATABASE IF NOT EXISTS mysqltest; | |||
| USE mysqltest; | |||
| CREATE TABLE IF NOT EXISTS t(c1 int); | |||
| CREATE TABLE IF NOT EXISTS t1 LIKE t; | |||
| CREATE TABLE IF NOT EXISTS t2 SELECT * FROM t; | |||
| CREATE EVENT IF NOT EXISTS e  | |||
| ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR  | |||
| DO SELECT now(); | |||
| SHOW TABLES in mysqltest; | |||
| Tables_in_mysqltest | |||
| t | |||
| t1 | |||
| t2 | |||
| SHOW EVENTS in mysqltest; | |||
| Db	Name	Definer	Time zone	Type	Execute at	Interval value	Interval field	Starts	Ends	Status	Originator	character_set_client	collation_connection	Database Collation | |||
| mysqltest	e	@	SYSTEM	ONE TIME	#	NULL	NULL	NULL	NULL	SLAVESIDE_DISABLED	1	latin1	latin1_swedish_ci	latin1_swedish_ci | |||
| DROP DATABASE IF EXISTS mysqltest; | |||
| @ -0,0 +1,22 @@ | |||
| stop slave; | |||
| drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9; | |||
| reset master; | |||
| reset slave; | |||
| drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9; | |||
| start slave; | |||
| DROP DATABASE IF EXISTS mysqltest; | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp(c1 int); | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp(c1 int); | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp1 LIKE tmp; | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp1 LIKE tmp; | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp2 SELECT * FROM tmp; | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp2 SELECT * FROM tmp; | |||
| show binlog events from <binlog_start>; | |||
| Log_name	Pos	Event_type	Server_id	End_log_pos	Info | |||
| master-bin.000001	#	Query	#	#	DROP DATABASE IF EXISTS mysqltest | |||
| master-bin.000001	#	Query	#	#	use `test`; CREATE TEMPORARY TABLE IF NOT EXISTS tmp(c1 int) | |||
| master-bin.000001	#	Query	#	#	use `test`; CREATE TEMPORARY TABLE IF NOT EXISTS tmp(c1 int) | |||
| master-bin.000001	#	Query	#	#	use `test`; CREATE TEMPORARY TABLE IF NOT EXISTS tmp1 LIKE tmp | |||
| master-bin.000001	#	Query	#	#	use `test`; CREATE TEMPORARY TABLE IF NOT EXISTS tmp1 LIKE tmp | |||
| master-bin.000001	#	Query	#	#	use `test`; CREATE TEMPORARY TABLE IF NOT EXISTS tmp2 SELECT * FROM tmp | |||
| master-bin.000001	#	Query	#	#	use `test`; CREATE TEMPORARY TABLE IF NOT EXISTS tmp2 SELECT * FROM tmp | |||
| @ -0,0 +1,70 @@ | |||
| # BUG#45574: | |||
| # SP: CREATE DATABASE|TABLE IF NOT EXISTS not binlogged if routine exists. | |||
| # | |||
| #   There is an inconsistency with DROP DATABASE|TABLE|EVENT IF EXISTS and | |||
| #   CREATE DATABASE|TABLE|EVENT IF NOT EXISTS. DROP IF EXISTS statements are | |||
| #   binlogged even if either the DB, TABLE or EVENT does not exist. In | |||
| #   contrast, Only the CREATE EVENT IF NOT EXISTS is binlogged when the EVENT | |||
| #   exists.   | |||
| # | |||
| #   This problem caused some of the tests to fail randomly on PB or PB2. | |||
| # | |||
| # Description:  | |||
| #   Fixed this bug by adding calls to write_bin_log in:  | |||
| #   mysql_create_db  | |||
| #   mysql_create_table_no_lock  | |||
| #   mysql_create_like_table  | |||
| #   create_table_from_items  | |||
| # | |||
| #   Test is implemented as follows:  | |||
| #   i) test each "CREATE IF NOT EXISTS" (DDL), found in MySQL 5.1 manual | |||
| #   exclude CREATE TEMPORARY TABLE, on existent objects;  | |||
| # | |||
| #  Note:  | |||
| #  rpl_create_tmp_table_if_not_exists.test tests CREATE TEMPORARY TABLE cases. | |||
| # | |||
| #  References: | |||
| #  http://dev.mysql.com/doc/refman/5.1/en/sql-syntax-data-definition.html | |||
| # | |||
| 
 | |||
| source include/master-slave.inc; | |||
| disable_warnings; | |||
| DROP DATABASE IF EXISTS mysqltest; | |||
| 
 | |||
| CREATE DATABASE IF NOT EXISTS mysqltest; | |||
| USE mysqltest; | |||
| CREATE TABLE IF NOT EXISTS t(c1 int); | |||
| CREATE TABLE IF NOT EXISTS t1 LIKE t; | |||
| CREATE TABLE IF NOT EXISTS t2 SELECT * FROM t; | |||
| CREATE EVENT IF NOT EXISTS e  | |||
| ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR  | |||
| DO SELECT now(); | |||
| sync_slave_with_master; | |||
| 
 | |||
| connection slave; | |||
| #DROP database from slave. | |||
| #The database and all tables can be recreated in slave  | |||
| #if binlog of the second CREATE command is recorded and sent from master to slave. | |||
| DROP DATABASE mysqltest; | |||
| 
 | |||
| connection master; | |||
| CREATE DATABASE IF NOT EXISTS mysqltest; | |||
| USE mysqltest; | |||
| CREATE TABLE IF NOT EXISTS t(c1 int); | |||
| CREATE TABLE IF NOT EXISTS t1 LIKE t; | |||
| CREATE TABLE IF NOT EXISTS t2 SELECT * FROM t; | |||
| CREATE EVENT IF NOT EXISTS e  | |||
| ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR  | |||
| DO SELECT now();  | |||
| sync_slave_with_master; | |||
| 
 | |||
| connection slave; | |||
| SHOW TABLES in mysqltest; | |||
| #Execution time changes in each run. So we disregard it by calling replace_column. | |||
| replace_column 6 #; | |||
| SHOW EVENTS in mysqltest; | |||
| 
 | |||
| 
 | |||
| connection master; | |||
| DROP DATABASE IF EXISTS mysqltest; | |||
| source include/master-slave-end.inc; | |||
| @ -0,0 +1,41 @@ | |||
| # BUG#45574:  | |||
| # SP: CREATE DATABASE|TABLE IF NOT EXISTS not binlogged if routine exists. | |||
| # | |||
| #   There is an inconsistency with DROP DATABASE|TABLE|EVENT IF EXISTS and | |||
| #   CREATE DATABASE|TABLE|EVENT IF NOT EXISTS. DROP IF EXISTS statements are | |||
| #   binlogged even if either the DB, TABLE or EVENT does not exist. In | |||
| #   contrast, Only the CREATE EVENT IF NOT EXISTS is binlogged when the EVENT | |||
| #   exists.   | |||
| # | |||
| #   This problem caused some of the tests to fail randomly on PB or PB2. | |||
| # | |||
| #   Test is implemented as follows: | |||
| # | |||
| #       i) test each "CREATE TEMPORARY TABLE IF EXISTS" (DDL), found in MySQL | |||
| #       5.1 manual, on existent objects;  | |||
| #       ii) show binlog events;  | |||
| # | |||
| #  Note:  | |||
| #  rpl_create_if_not_exists.test tests other cases. | |||
| # | |||
| #  References: | |||
| #  http://dev.mysql.com/doc/refman/5.1/en/sql-syntax-data-definition.html | |||
| # | |||
| 
 | |||
| source include/master-slave.inc; | |||
| #CREATE TEMPORARY TABLE statements are not binlogged in row mode, | |||
| #So it must be test by itself. | |||
| source include/have_binlog_format_mixed_or_statement.inc; | |||
| disable_warnings; | |||
| 
 | |||
| DROP DATABASE IF EXISTS mysqltest; | |||
| 
 | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp(c1 int); | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp(c1 int); | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp1 LIKE tmp; | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp1 LIKE tmp; | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp2 SELECT * FROM tmp; | |||
| CREATE TEMPORARY TABLE IF NOT EXISTS tmp2 SELECT * FROM tmp; | |||
| source include/show_binlog_events.inc; | |||
| 
 | |||
| source include/master-slave-end.inc; | |||
						Write
						Preview
					
					
					Loading…
					
					Cancel
						Save
					
		Reference in new issue