2005-12-22 06:39:02 +01:00
|
|
|
# TBF - difference in row level logging
|
2006-08-30 10:22:43 +03:00
|
|
|
-- source include/have_binlog_format_mixed_or_statement.inc
|
2005-12-22 06:39:02 +01:00
|
|
|
-- source include/master-slave.inc
|
|
|
|
|
2004-10-19 22:27:19 +02:00
|
|
|
--disable_warnings
|
|
|
|
drop database if exists mysqltest1;
|
|
|
|
--enable_warnings
|
|
|
|
create database mysqltest1;
|
|
|
|
|
|
|
|
use mysqltest1;
|
|
|
|
create table t1 (a int);
|
|
|
|
insert into t1 values(9);
|
|
|
|
select * from mysqltest1.t1;
|
|
|
|
sync_slave_with_master;
|
|
|
|
show databases like 'mysqltest1'; # should be empty
|
|
|
|
select * from test.t1;
|
|
|
|
# cleanup
|
|
|
|
connection master;
|
|
|
|
drop table t1;
|
|
|
|
drop database mysqltest1;
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
2004-11-15 17:03:54 +01:00
|
|
|
#
|
|
|
|
# BUG#6353:
|
|
|
|
# Option --replicate-rewrite-db should work together with LOAD DATA INFILE
|
|
|
|
#
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
--disable_warnings
|
|
|
|
drop database if exists rewrite;
|
|
|
|
--enable_warnings
|
|
|
|
create database rewrite;
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
use test;
|
|
|
|
create table t1 (a date, b date, c date not null, d date);
|
2007-12-12 18:19:24 +01:00
|
|
|
load data infile '../../std_data/loaddata1.dat' into table t1 fields terminated by ',';
|
|
|
|
load data infile '../../std_data/loaddata1.dat' into table t1 fields terminated by ',' IGNORE 2 LINES;
|
2004-11-15 17:03:54 +01:00
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
select * from rewrite.t1;
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
truncate table t1;
|
2007-12-12 18:19:24 +01:00
|
|
|
load data infile '../../std_data/loaddata1.dat' into table t1 fields terminated by ',' LINES STARTING BY ',' (b,c,d);
|
2004-11-15 17:03:54 +01:00
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
select * from rewrite.t1;
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
drop table t1;
|
|
|
|
create table t1 (a text, b text);
|
2007-12-12 18:19:24 +01:00
|
|
|
load data infile '../../std_data/loaddata2.dat' into table t1 fields terminated by ',' enclosed by '''';
|
2004-11-15 17:03:54 +01:00
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
select concat('|',a,'|'), concat('|',b,'|') from rewrite.t1;
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
drop table t1;
|
|
|
|
create table t1 (a int, b char(10));
|
2007-12-12 18:19:24 +01:00
|
|
|
load data infile '../../std_data/loaddata3.dat' into table t1 fields terminated by '' enclosed by '' ignore 1 lines;
|
2004-11-15 17:03:54 +01:00
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
select * from rewrite.t1;
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
truncate table t1;
|
2007-12-12 18:19:24 +01:00
|
|
|
load data infile '../../std_data/loaddata4.dat' into table t1 fields terminated by '' enclosed by '' lines terminated by '' ignore 1 lines;
|
2004-11-15 17:03:54 +01:00
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
# The empty line last comes from the end line field in the file
|
|
|
|
select * from rewrite.t1;
|
|
|
|
|
2009-08-27 17:28:09 +01:00
|
|
|
set sql_log_bin= 0;
|
2005-04-06 12:20:55 +02:00
|
|
|
drop database rewrite;
|
2009-08-27 17:28:09 +01:00
|
|
|
set sql_log_bin= 1;
|
2005-04-06 12:20:55 +02:00
|
|
|
|
2004-11-15 17:03:54 +01:00
|
|
|
connection master;
|
2009-08-27 17:28:09 +01:00
|
|
|
set sql_log_bin= 0;
|
2004-11-15 17:03:54 +01:00
|
|
|
drop table t1;
|
2009-08-27 17:28:09 +01:00
|
|
|
set sql_log_bin= 1;
|
2005-04-06 12:20:55 +02:00
|
|
|
|
2005-07-28 03:22:47 +03:00
|
|
|
# End of 4.1 tests
|
2009-08-27 17:28:09 +01:00
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo ****
|
|
|
|
--echo **** Bug #46861 Auto-closing of temporary tables broken by replicate-rewrite-db
|
|
|
|
--echo ****
|
|
|
|
--echo
|
|
|
|
|
|
|
|
--echo ****
|
|
|
|
--echo **** Preparing the environment
|
|
|
|
--echo ****
|
|
|
|
connection master;
|
|
|
|
|
|
|
|
connect (con_temp_03,127.0.0.1,root,,test,$MASTER_MYPORT,);
|
|
|
|
connect (con_temp_02,127.0.0.1,root,,test,$MASTER_MYPORT,);
|
|
|
|
connect (con_temp_01,127.0.0.1,root,,test,$MASTER_MYPORT,);
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
SET sql_log_bin= 0;
|
|
|
|
CREATE DATABASE database_master_temp_01;
|
|
|
|
CREATE DATABASE database_master_temp_02;
|
|
|
|
CREATE DATABASE database_master_temp_03;
|
|
|
|
SET sql_log_bin= 1;
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
SET sql_log_bin= 0;
|
|
|
|
CREATE DATABASE database_slave_temp_01;
|
|
|
|
CREATE DATABASE database_slave_temp_02;
|
|
|
|
CREATE DATABASE database_slave_temp_03;
|
|
|
|
SET sql_log_bin= 1;
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo ****
|
|
|
|
--echo **** Creating temporary tables on different databases with different connections
|
|
|
|
--echo ****
|
|
|
|
--echo **** con_temp_01 --> creates
|
|
|
|
--echo **** t_01_01_temp on database_master_temp_01
|
|
|
|
--echo ****
|
|
|
|
--echo **** con_temp_02 --> creates
|
|
|
|
--echo **** t_01_01_temp on database_master_temp_01
|
|
|
|
--echo **** t_02_01_temp, t_02_02_temp on database_master_temp_02
|
|
|
|
--echo ****
|
|
|
|
--echo **** con_temp_02 --> creates
|
|
|
|
--echo **** t_01_01_temp on database_master_temp_01
|
|
|
|
--echo **** t_02_01_temp, t_02_02_temp on database_master_temp_02
|
|
|
|
--echo **** t_03_01_temp, t_03_02_temp, t_03_03_temp on database_master_temp_03
|
|
|
|
--echo ****
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo con_temp_01
|
|
|
|
--echo
|
|
|
|
connection con_temp_01;
|
|
|
|
USE database_master_temp_01;
|
|
|
|
CREATE TEMPORARY TABLE t_01_01_temp(a int);
|
|
|
|
INSERT INTO t_01_01_temp VALUES(1);
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo con_temp_02
|
|
|
|
--echo
|
|
|
|
connection con_temp_02;
|
|
|
|
USE database_master_temp_01;
|
|
|
|
CREATE TEMPORARY TABLE t_01_01_temp(a int);
|
|
|
|
INSERT INTO t_01_01_temp VALUES(1);
|
|
|
|
USE database_master_temp_02;
|
|
|
|
CREATE TEMPORARY TABLE t_02_01_temp(a int);
|
|
|
|
INSERT INTO t_02_01_temp VALUES(1);
|
|
|
|
CREATE TEMPORARY TABLE t_02_02_temp(a int);
|
|
|
|
INSERT INTO t_02_02_temp VALUES(1);
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo con_temp_03
|
|
|
|
--echo
|
|
|
|
connection con_temp_03;
|
|
|
|
USE database_master_temp_01;
|
|
|
|
CREATE TEMPORARY TABLE t_01_01_temp(a int);
|
|
|
|
INSERT INTO t_01_01_temp VALUES(1);
|
|
|
|
USE database_master_temp_02;
|
|
|
|
CREATE TEMPORARY TABLE t_02_01_temp(a int);
|
|
|
|
INSERT INTO t_02_01_temp VALUES(1);
|
|
|
|
CREATE TEMPORARY TABLE t_02_02_temp(a int);
|
|
|
|
INSERT INTO t_02_02_temp VALUES(1);
|
|
|
|
USE database_master_temp_03;
|
|
|
|
CREATE TEMPORARY TABLE t_03_01_temp(a int);
|
|
|
|
INSERT INTO t_03_01_temp VALUES(1);
|
|
|
|
CREATE TEMPORARY TABLE t_03_02_temp(a int);
|
|
|
|
INSERT INTO t_03_02_temp VALUES(1);
|
|
|
|
CREATE TEMPORARY TABLE t_03_03_temp(a int);
|
|
|
|
INSERT INTO t_03_03_temp VALUES(1);
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo **** Dropping the connections
|
|
|
|
--echo **** We want to SHOW BINLOG EVENTS, to know what was logged. But there is no
|
|
|
|
--echo **** guarantee that logging of the terminated con1 has been done yet.a To be
|
|
|
|
--echo **** sure that logging has been done, we use a user lock.
|
|
|
|
--echo
|
|
|
|
connection master;
|
|
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
|
|
show status like 'Slave_open_temp_tables';
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
let $binlog_start= query_get_value(SHOW MASTER STATUS, Position, 1);
|
|
|
|
connection con_temp_01;
|
|
|
|
select get_lock("con_01",10);
|
|
|
|
connection master;
|
|
|
|
disconnect con_temp_01;
|
|
|
|
select get_lock("con_01",10);
|
|
|
|
|
|
|
|
connection con_temp_02;
|
|
|
|
select get_lock("con_02",10);
|
|
|
|
connection master;
|
|
|
|
disconnect con_temp_02;
|
|
|
|
select get_lock("con_02",10);
|
|
|
|
|
|
|
|
connection con_temp_03;
|
|
|
|
select get_lock("con_03",10);
|
|
|
|
connection master;
|
|
|
|
disconnect con_temp_03;
|
|
|
|
select get_lock("con_03",10);
|
|
|
|
|
|
|
|
--echo
|
|
|
|
--echo **** Checking the binary log and temporary tables
|
|
|
|
--echo
|
|
|
|
connection master;
|
|
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
|
|
show status like 'Slave_open_temp_tables';
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
--source include/show_binlog_events.inc
|
|
|
|
|
|
|
|
--echo ****
|
|
|
|
--echo **** Cleaning up the test case
|
|
|
|
--echo ****
|
|
|
|
connection master;
|
|
|
|
SET sql_log_bin= 0;
|
|
|
|
DROP DATABASE database_master_temp_01;
|
|
|
|
DROP DATABASE database_master_temp_02;
|
|
|
|
DROP DATABASE database_master_temp_03;
|
|
|
|
SET sql_log_bin= 1;
|
|
|
|
|
|
|
|
connection slave;
|
|
|
|
SET sql_log_bin= 0;
|
|
|
|
DROP DATABASE database_slave_temp_01;
|
|
|
|
DROP DATABASE database_slave_temp_02;
|
|
|
|
DROP DATABASE database_slave_temp_03;
|
|
|
|
SET sql_log_bin= 1;
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
|
|
# end of 5.0 tests
|