# # Test of replicating user variables # ########################################################### # 2006-02-08 By JBM added order by for use w/ NDB engine ########################################################### source include/master-slave.inc; #save_master_pos; #connection slave; #sync_with_master; #reset master; #connection master; --disable_warnings drop table if exists t1; --enable_warnings create table t1(n char(30)); prepare stmt1 from 'insert into t1 values (?)'; set @var1= "from-master-1"; execute stmt1 using @var1; set @var1= "from-master-2-'',"; execute stmt1 using @var1; SELECT * FROM t1 ORDER BY n; set @var2= 'insert into t1 values (concat("from-var-", ?))'; prepare stmt2 from @var2; set @var1='from-master-3'; execute stmt2 using @var1; save_master_pos; connection slave; sync_with_master; SELECT * FROM t1 ORDER BY n; connection master; drop table t1; save_master_pos; connection slave; sync_with_master; stop slave; # End of 4.1 tests # # Bug #25843 Changing default database between PREPARE and EXECUTE of statement # breaks binlog. # # There were actually two problems discovered by this bug: # # 1. Default (current) database is not fixed at the creation time. # That leads to wrong output of DATABASE() function. # # 2. Database attributes (@@collation_database) are not fixed at the creation # time. That leads to wrong resultset. # # Binlog breakage and Query Cache wrong output happened because of the first # problem. # --echo --echo ######################################################################## --echo # --echo # BUG#25843: Changing default database between PREPARE and EXECUTE of --echo # statement breaks binlog. --echo # --echo ######################################################################## ############################################################################### --echo --echo # Connection: slave --echo --connection slave --echo START SLAVE; --echo --echo # Connection: master --echo --connection master --echo CREATE DATABASE mysqltest1; CREATE TABLE t1(db_name CHAR(32), db_col_name CHAR(32)); --echo PREPARE stmt_d_1 FROM 'INSERT INTO t1 VALUES(DATABASE(), @@collation_database)'; --echo EXECUTE stmt_d_1; --echo use mysqltest1; --echo EXECUTE stmt_d_1; --echo --save_master_pos --echo --echo # Connection: slave --echo --connection slave --sync_with_master --echo SELECT * FROM t1; --echo --echo # Connection: master --echo --connection master --echo DROP DATABASE mysqltest1; --echo use test; --echo --save_master_pos --echo --echo # Connection: slave --echo --connection slave --sync_with_master --echo STOP SLAVE; --echo --echo ######################################################################## ############################################################################### reset master; reset slave; disconnect master;