mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 00:34:18 +01:00
2b2ce3d6cb
In statement-based or mixed-mode replication, use DROP TEMPORARY TABLE to drop multiple tables causes different errors on master and slave, when one or more of these tables do not exist. Because when executed on slave, it would automatically add IF EXISTS to the query to ignore all ER_BAD_TABLE_ERROR errors. To fix the problem, do not add IF EXISTS when executing DROP TEMPORARY TABLE on the slave, and clear the ER_BAD_TABLE_ERROR error after execution if the query does not expect any errors. mysql-test/r/rpl_drop_temp.result: Updated for the patch of bug#49137. mysql-test/t/rpl_drop_temp.test: Added the test file to verify if DROP MULTI TEMPORARY TABLE will cause different errors on master and slave, when one or more of these tables do not exist. sql/log_event.cc: Added code to handle above cases which are removed from sql_parse.cc sql/sql_parse.cc: Remove the code to issue the 'Unknown table' error, if the temporary table does not exist when dropping it on slave. The above cases decribed in comments will be handled later in log_event.cc.
34 lines
908 B
Text
34 lines
908 B
Text
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;
|
|
create database if not exists mysqltest;
|
|
use mysqltest;
|
|
create temporary table mysqltest.t1 (n int);
|
|
create temporary table mysqltest.t2 (n int);
|
|
select get_lock("con_temp",10);
|
|
get_lock("con_temp",10)
|
|
1
|
|
select get_lock("con_temp",10);
|
|
get_lock("con_temp",10)
|
|
1
|
|
show status like 'Slave_open_temp_tables';
|
|
Variable_name Value
|
|
Slave_open_temp_tables 0
|
|
drop database mysqltest;
|
|
DROP TEMPORARY TABLE IF EXISTS tmp1;
|
|
Warnings:
|
|
Note 1051 Unknown table 'tmp1'
|
|
CREATE TEMPORARY TABLE t1 ( a int );
|
|
DROP TEMPORARY TABLE t1, t2;
|
|
ERROR 42S02: Unknown table 't2'
|
|
DROP TEMPORARY TABLE tmp2;
|
|
ERROR 42S02: Unknown table 'tmp2'
|
|
stop slave;
|
|
**** On Master ****
|
|
CREATE TEMPORARY TABLE tmp3 (a int);
|
|
DROP TEMPORARY TABLE tmp3;
|
|
SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
|
|
START SLAVE;
|