include/master-slave.inc Warnings: Note #### Sending passwords in plain text without SSL/TLS is extremely insecure. Note #### Storing MySQL user name or password information in the master info repository is not secure and is therefore not recommended. Please consider using the USER and PASSWORD connection options for START SLAVE; see the 'START SLAVE Syntax' in the MySQL Manual for more information. [connection master] ==== Initialization ==== [on master] SET @m_default_week_format= @@global.default_week_format; SET @m_init_slave= @@global.init_slave; SET @m_lc_time_names= @@global.lc_time_names; SET @m_low_priority_updates= @@global.low_priority_updates; SET @m_relay_log_purge= @@global.relay_log_purge; SET @m_slave_exec_mode= @@global.slave_exec_mode; SET @m_sql_mode= @@global.sql_mode; SET @m_sync_binlog= @@global.sync_binlog; [on slave] SET @s_default_week_format= @@global.default_week_format; SET @s_init_slave= @@global.init_slave; SET @s_lc_time_names= @@global.lc_time_names; SET @s_low_priority_updates= @@global.low_priority_updates; SET @s_relay_log_purge= @@global.relay_log_purge; SET @s_slave_exec_mode= @@global.slave_exec_mode; SET @s_sql_mode= @@global.sql_mode; SET @s_sync_binlog= @@global.sync_binlog; SET @@global.relay_log_purge = OFF; SET @@global.sync_binlog = 1000000; SET @@global.slave_exec_mode = 'STRICT'; SET @@sql_big_selects = OFF; SET @@last_insert_id = 10; SET @@global.low_priority_updates = OFF; SET @@local.low_priority_updates = OFF; SET @@global.default_week_format = 1; SET @@local.default_week_format = 2; SET @@global.lc_time_names = 'zh_HK'; SET @@local.lc_time_names = 'zh_TW'; SET @@global.sql_mode = 'ALLOW_INVALID_DATES'; SET @@local.sql_mode = 'ANSI_QUOTES,ERROR_FOR_DIVISION_BY_ZERO,HIGH_NOT_PRECEDENCE'; Warnings: Warning 1681 'ERROR_FOR_DIVISION_BY_ZERO' is deprecated and will be removed in a future release. SET @user_num = 10; SET @user_text = 'Alunda'; include/stop_slave.inc include/start_slave.inc SET @@global.init_slave = 'SELECT 1'; [on master] SELECT @@pid_file, @@datadir; @@pid_file MYSQLTEST_VARDIR/run/mysqld.1.pid @@datadir MYSQLTEST_VARDIR/mysqld.1/data/ **** Relay log variables SELECT @@relay_log, @@relay_log_index, @@relay_log_basename; @@relay_log NULL @@relay_log_index NULL @@relay_log_basename NULL **** Binary log variables SELECT @@log_bin, @@log_bin_index, @@log_bin_basename; @@log_bin 1 @@log_bin_index MYSQLTEST_VARDIR/mysqld.1/data/master-bin.index @@log_bin_basename MYSQLTEST_VARDIR/mysqld.1/data/master-bin [on slave] SELECT @@pid_file, @@datadir; @@pid_file MYSQLTEST_VARDIR/run/mysqld.2.pid @@datadir MYSQLTEST_VARDIR/mysqld.2/data/ **** Relay log variables SELECT @@relay_log, @@relay_log_index, @@relay_log_basename; @@relay_log slave-relay-bin @@relay_log_index MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin.index @@relay_log_basename MYSQLTEST_VARDIR/mysqld.2/data/slave-relay-bin **** Binary log variables SELECT @@log_bin, @@log_bin_index, @@log_bin_basename; @@log_bin 1 @@log_bin_index MYSQLTEST_VARDIR/mysqld.2/data/slave-bin.index @@log_bin_basename MYSQLTEST_VARDIR/mysqld.2/data/slave-bin [on master] CREATE TABLE tstmt (id INT AUTO_INCREMENT PRIMARY KEY, truth BOOLEAN, num INT, text VARCHAR(100)); CREATE TABLE tproc LIKE tstmt; CREATE TABLE tfunc LIKE tstmt; CREATE TABLE ttrig LIKE tstmt; CREATE TABLE tprep LIKE tstmt; CREATE TABLE trigger_table (text CHAR(4)); ==== Insert variables directly ==== ---- global variables ---- SET @@global.relay_log_purge = ON; INSERT INTO tstmt(truth) VALUES (@@global.relay_log_purge); SET @@global.relay_log_purge = OFF; INSERT INTO tstmt(truth) VALUES (@@global.relay_log_purge); SET @@global.sync_binlog = 2000000; INSERT INTO tstmt(num) VALUES (@@global.sync_binlog); SET @@global.sync_binlog = 3000000; INSERT INTO tstmt(num) VALUES (@@global.sync_binlog); SET @@global.init_slave = 'SELECT 2'; INSERT INTO tstmt(text) VALUES (@@global.init_slave); SET @@global.init_slave = 'SELECT 3'; INSERT INTO tstmt(text) VALUES (@@global.init_slave); SET @@global.slave_exec_mode = 'IDEMPOTENT'; INSERT INTO tstmt(text) VALUES (@@global.slave_exec_mode); SET @@global.slave_exec_mode = 'STRICT'; INSERT INTO tstmt(text) VALUES (@@global.slave_exec_mode); ---- session variables ---- SET @@sql_big_selects = ON; INSERT INTO tstmt(truth) VALUES (@@sql_big_selects); SET @@sql_big_selects = OFF; INSERT INTO tstmt(truth) VALUES (@@sql_big_selects); SET @@last_insert_id = 20; INSERT INTO tstmt(num) VALUES (@@last_insert_id); SET @@last_insert_id = 30; INSERT INTO tstmt(num) VALUES (@@last_insert_id); ---- global and session variables ---- SET @@global.low_priority_updates = ON; SET @@local.low_priority_updates = OFF; INSERT INTO tstmt(truth) VALUES (@@global.low_priority_updates); INSERT INTO tstmt(truth) VALUES (@@local.low_priority_updates); SET @@global.low_priority_updates = OFF; SET @@local.low_priority_updates = ON; INSERT INTO tstmt(truth) VALUES (@@global.low_priority_updates); INSERT INTO tstmt(truth) VALUES (@@local.low_priority_updates); SET @@global.default_week_format = 3; SET @@local.default_week_format = 4; INSERT INTO tstmt(num) VALUES (@@global.default_week_format); INSERT INTO tstmt(num) VALUES (@@local.default_week_format); SET @@global.default_week_format = 5; SET @@local.default_week_format = 6; INSERT INTO tstmt(num) VALUES (@@global.default_week_format); INSERT INTO tstmt(num) VALUES (@@local.default_week_format); SET @@global.lc_time_names = 'sv_SE'; SET @@local.lc_time_names = 'sv_FI'; INSERT INTO tstmt(text) VALUES (@@global.lc_time_names); INSERT INTO tstmt(text) VALUES (@@local.lc_time_names); SET @@global.lc_time_names = 'ar_TN'; SET @@local.lc_time_names = 'ar_IQ'; INSERT INTO tstmt(text) VALUES (@@global.lc_time_names); INSERT INTO tstmt(text) VALUES (@@local.lc_time_names); SET @@global.sql_mode = ''; SET @@local.sql_mode = 'IGNORE_SPACE,NO_AUTO_CREATE_USER'; INSERT INTO tstmt(text) VALUES (@@global.sql_mode); INSERT INTO tstmt(text) VALUES (@@local.sql_mode); SET @@global.sql_mode = 'NO_AUTO_VALUE_ON_ZERO,NO_BACKSLASH_ESCAPES,NO_DIR_IN_CREATE,NO_ENGINE_SUBSTITUTION'; SET @@local.sql_mode = 'NO_FIELD_OPTIONS,NO_KEY_OPTIONS,NO_TABLE_OPTIONS'; INSERT INTO tstmt(text) VALUES (@@global.sql_mode); INSERT INTO tstmt(text) VALUES (@@local.sql_mode); ---- user variables ---- SET @user_num = 20; INSERT INTO tstmt(num) VALUES (@user_num); SET @user_num = 30; INSERT INTO tstmt(num) VALUES (@user_num); SET @user_text = 'Bergsbrunna'; INSERT INTO tstmt(text) VALUES (@user_text); SET @user_text = 'Centrum'; INSERT INTO tstmt(text) VALUES (@user_text); ==== Insert variables from a stored procedure ==== CREATE PROCEDURE proc() BEGIN # GLOBAL # boolean SET @@global.relay_log_purge = ON; INSERT INTO tproc(truth) VALUES (@@global.relay_log_purge); SET @@global.relay_log_purge = OFF; INSERT INTO tproc(truth) VALUES (@@global.relay_log_purge); # numeric SET @@global.sync_binlog = 2000000; INSERT INTO tproc(num) VALUES (@@global.sync_binlog); SET @@global.sync_binlog = 3000000; INSERT INTO tproc(num) VALUES (@@global.sync_binlog); # string SET @@global.init_slave = 'SELECT 2'; INSERT INTO tproc(text) VALUES (@@global.init_slave); SET @@global.init_slave = 'SELECT 3'; INSERT INTO tproc(text) VALUES (@@global.init_slave); # enumeration SET @@global.slave_exec_mode = 'IDEMPOTENT'; INSERT INTO tproc(text) VALUES (@@global.slave_exec_mode); SET @@global.slave_exec_mode = 'STRICT'; INSERT INTO tproc(text) VALUES (@@global.slave_exec_mode); # SESSION # boolean SET @@sql_big_selects = ON; INSERT INTO tproc(truth) VALUES (@@sql_big_selects); SET @@sql_big_selects = OFF; INSERT INTO tproc(truth) VALUES (@@sql_big_selects); # numeric SET @@last_insert_id = 20; INSERT INTO tproc(num) VALUES (@@last_insert_id); SET @@last_insert_id = 30; INSERT INTO tproc(num) VALUES (@@last_insert_id); # BOTH # boolean SET @@global.low_priority_updates = ON; SET @@local.low_priority_updates = OFF; INSERT INTO tproc(truth) VALUES (@@global.low_priority_updates); INSERT INTO tproc(truth) VALUES (@@local.low_priority_updates); SET @@global.low_priority_updates = OFF; SET @@local.low_priority_updates = ON; INSERT INTO tproc(truth) VALUES (@@global.low_priority_updates); INSERT INTO tproc(truth) VALUES (@@local.low_priority_updates); # numeric SET @@global.default_week_format = 3; SET @@local.default_week_format = 4; INSERT INTO tproc(num) VALUES (@@global.default_week_format); INSERT INTO tproc(num) VALUES (@@local.default_week_format); SET @@global.default_week_format = 5; SET @@local.default_week_format = 6; INSERT INTO tproc(num) VALUES (@@global.default_week_format); INSERT INTO tproc(num) VALUES (@@local.default_week_format); # text SET @@global.lc_time_names = 'sv_SE'; SET @@local.lc_time_names = 'sv_FI'; INSERT INTO tproc(text) VALUES (@@global.lc_time_names); INSERT INTO tproc(text) VALUES (@@local.lc_time_names); SET @@global.lc_time_names = 'ar_TN'; SET @@local.lc_time_names = 'ar_IQ'; INSERT INTO tproc(text) VALUES (@@global.lc_time_names); INSERT INTO tproc(text) VALUES (@@local.lc_time_names); # enum SET @@global.sql_mode = ''; SET @@local.sql_mode = 'IGNORE_SPACE,NO_AUTO_CREATE_USER'; INSERT INTO tproc(text) VALUES (@@global.sql_mode); INSERT INTO tproc(text) VALUES (@@local.sql_mode); SET @@global.sql_mode = 'NO_AUTO_VALUE_ON_ZERO,NO_BACKSLASH_ESCAPES,NO_DIR_IN_CREATE,NO_ENGINE_SUBSTITUTION'; SET @@local.sql_mode = 'NO_FIELD_OPTIONS,NO_KEY_OPTIONS,NO_TABLE_OPTIONS'; INSERT INTO tproc(text) VALUES (@@global.sql_mode); INSERT INTO tproc(text) VALUES (@@local.sql_mode); # USER # numeric SET @user_num = 20; INSERT INTO tproc(num) VALUES (@user_num); SET @user_num = 30; INSERT INTO tproc(num) VALUES (@user_num); # string SET @user_text = 'Bergsbrunna'; INSERT INTO tproc(text) VALUES (@user_text); SET @user_text = 'Centrum'; INSERT INTO tproc(text) VALUES (@user_text); END| CALL proc(); ==== Insert variables from a stored function ==== CREATE FUNCTION func() RETURNS INT BEGIN # GLOBAL # boolean SET @@global.relay_log_purge = ON; INSERT INTO tfunc(truth) VALUES (@@global.relay_log_purge); SET @@global.relay_log_purge = OFF; INSERT INTO tfunc(truth) VALUES (@@global.relay_log_purge); # numeric SET @@global.sync_binlog = 2000000; INSERT INTO tfunc(num) VALUES (@@global.sync_binlog); SET @@global.sync_binlog = 3000000; INSERT INTO tfunc(num) VALUES (@@global.sync_binlog); # string SET @@global.init_slave = 'SELECT 2'; INSERT INTO tfunc(text) VALUES (@@global.init_slave); SET @@global.init_slave = 'SELECT 3'; INSERT INTO tfunc(text) VALUES (@@global.init_slave); # enumeration SET @@global.slave_exec_mode = 'IDEMPOTENT'; INSERT INTO tfunc(text) VALUES (@@global.slave_exec_mode); SET @@global.slave_exec_mode = 'STRICT'; INSERT INTO tfunc(text) VALUES (@@global.slave_exec_mode); # SESSION # boolean SET @@sql_big_selects = ON; INSERT INTO tfunc(truth) VALUES (@@sql_big_selects); SET @@sql_big_selects = OFF; INSERT INTO tfunc(truth) VALUES (@@sql_big_selects); # numeric SET @@last_insert_id = 20; INSERT INTO tfunc(num) VALUES (@@last_insert_id); SET @@last_insert_id = 30; INSERT INTO tfunc(num) VALUES (@@last_insert_id); # BOTH # boolean SET @@global.low_priority_updates = ON; SET @@local.low_priority_updates = OFF; INSERT INTO tfunc(truth) VALUES (@@global.low_priority_updates); INSERT INTO tfunc(truth) VALUES (@@local.low_priority_updates); SET @@global.low_priority_updates = OFF; SET @@local.low_priority_updates = ON; INSERT INTO tfunc(truth) VALUES (@@global.low_priority_updates); INSERT INTO tfunc(truth) VALUES (@@local.low_priority_updates); # numeric SET @@global.default_week_format = 3; SET @@local.default_week_format = 4; INSERT INTO tfunc(num) VALUES (@@global.default_week_format); INSERT INTO tfunc(num) VALUES (@@local.default_week_format); SET @@global.default_week_format = 5; SET @@local.default_week_format = 6; INSERT INTO tfunc(num) VALUES (@@global.default_week_format); INSERT INTO tfunc(num) VALUES (@@local.default_week_format); # text SET @@global.lc_time_names = 'sv_SE'; SET @@local.lc_time_names = 'sv_FI'; INSERT INTO tfunc(text) VALUES (@@global.lc_time_names); INSERT INTO tfunc(text) VALUES (@@local.lc_time_names); SET @@global.lc_time_names = 'ar_TN'; SET @@local.lc_time_names = 'ar_IQ'; INSERT INTO tfunc(text) VALUES (@@global.lc_time_names); INSERT INTO tfunc(text) VALUES (@@local.lc_time_names); # enum SET @@global.sql_mode = ''; SET @@local.sql_mode = 'IGNORE_SPACE,NO_AUTO_CREATE_USER'; INSERT INTO tfunc(text) VALUES (@@global.sql_mode); INSERT INTO tfunc(text) VALUES (@@local.sql_mode); SET @@global.sql_mode = 'NO_AUTO_VALUE_ON_ZERO,NO_BACKSLASH_ESCAPES,NO_DIR_IN_CREATE,NO_ENGINE_SUBSTITUTION'; SET @@local.sql_mode = 'NO_FIELD_OPTIONS,NO_KEY_OPTIONS,NO_TABLE_OPTIONS'; INSERT INTO tfunc(text) VALUES (@@global.sql_mode); INSERT INTO tfunc(text) VALUES (@@local.sql_mode); # USER # numeric SET @user_num = 20; INSERT INTO tfunc(num) VALUES (@user_num); SET @user_num = 30; INSERT INTO tfunc(num) VALUES (@user_num); # string SET @user_text = 'Bergsbrunna'; INSERT INTO tfunc(text) VALUES (@user_text); SET @user_text = 'Centrum'; INSERT INTO tfunc(text) VALUES (@user_text); RETURN 0; END| SELECT func(); func() 0 ==== Insert variables from a trigger ==== CREATE TRIGGER trig BEFORE INSERT ON trigger_table FOR EACH ROW BEGIN # GLOBAL # boolean SET @@global.relay_log_purge = ON; INSERT INTO ttrig(truth) VALUES (@@global.relay_log_purge); SET @@global.relay_log_purge = OFF; INSERT INTO ttrig(truth) VALUES (@@global.relay_log_purge); # numeric SET @@global.sync_binlog = 2000000; INSERT INTO ttrig(num) VALUES (@@global.sync_binlog); SET @@global.sync_binlog = 3000000; INSERT INTO ttrig(num) VALUES (@@global.sync_binlog); # string SET @@global.init_slave = 'SELECT 2'; INSERT INTO ttrig(text) VALUES (@@global.init_slave); SET @@global.init_slave = 'SELECT 3'; INSERT INTO ttrig(text) VALUES (@@global.init_slave); # enumeration SET @@global.slave_exec_mode = 'IDEMPOTENT'; INSERT INTO ttrig(text) VALUES (@@global.slave_exec_mode); SET @@global.slave_exec_mode = 'STRICT'; INSERT INTO ttrig(text) VALUES (@@global.slave_exec_mode); # SESSION # boolean SET @@sql_big_selects = ON; INSERT INTO ttrig(truth) VALUES (@@sql_big_selects); SET @@sql_big_selects = OFF; INSERT INTO ttrig(truth) VALUES (@@sql_big_selects); # numeric SET @@last_insert_id = 20; INSERT INTO ttrig(num) VALUES (@@last_insert_id); SET @@last_insert_id = 30; INSERT INTO ttrig(num) VALUES (@@last_insert_id); # BOTH # boolean SET @@global.low_priority_updates = ON; SET @@local.low_priority_updates = OFF; INSERT INTO ttrig(truth) VALUES (@@global.low_priority_updates); INSERT INTO ttrig(truth) VALUES (@@local.low_priority_updates); SET @@global.low_priority_updates = OFF; SET @@local.low_priority_updates = ON; INSERT INTO ttrig(truth) VALUES (@@global.low_priority_updates); INSERT INTO ttrig(truth) VALUES (@@local.low_priority_updates); # numeric SET @@global.default_week_format = 3; SET @@local.default_week_format = 4; INSERT INTO ttrig(num) VALUES (@@global.default_week_format); INSERT INTO ttrig(num) VALUES (@@local.default_week_format); SET @@global.default_week_format = 5; SET @@local.default_week_format = 6; INSERT INTO ttrig(num) VALUES (@@global.default_week_format); INSERT INTO ttrig(num) VALUES (@@local.default_week_format); # text SET @@global.lc_time_names = 'sv_SE'; SET @@local.lc_time_names = 'sv_FI'; INSERT INTO ttrig(text) VALUES (@@global.lc_time_names); INSERT INTO ttrig(text) VALUES (@@local.lc_time_names); SET @@global.lc_time_names = 'ar_TN'; SET @@local.lc_time_names = 'ar_IQ'; INSERT INTO ttrig(text) VALUES (@@global.lc_time_names); INSERT INTO ttrig(text) VALUES (@@local.lc_time_names); # enum SET @@global.sql_mode = ''; SET @@local.sql_mode = 'IGNORE_SPACE,NO_AUTO_CREATE_USER'; INSERT INTO ttrig(text) VALUES (@@global.sql_mode); INSERT INTO ttrig(text) VALUES (@@local.sql_mode); SET @@global.sql_mode = 'NO_AUTO_VALUE_ON_ZERO,NO_BACKSLASH_ESCAPES,NO_DIR_IN_CREATE,NO_ENGINE_SUBSTITUTION'; SET @@local.sql_mode = 'NO_FIELD_OPTIONS,NO_KEY_OPTIONS,NO_TABLE_OPTIONS'; INSERT INTO ttrig(text) VALUES (@@global.sql_mode); INSERT INTO ttrig(text) VALUES (@@local.sql_mode); # USER # numeric SET @user_num = 20; INSERT INTO ttrig(num) VALUES (@user_num); SET @user_num = 30; INSERT INTO ttrig(num) VALUES (@user_num); # string SET @user_text = 'Bergsbrunna'; INSERT INTO ttrig(text) VALUES (@user_text); SET @user_text = 'Centrum'; INSERT INTO ttrig(text) VALUES (@user_text); END| INSERT INTO trigger_table VALUES ('bye.'); ==== Insert variables from a prepared statement ==== PREPARE p1 FROM 'SET @@global.relay_log_purge = ON'; PREPARE p2 FROM 'INSERT INTO tprep(truth) VALUES (@@global.relay_log_purge)'; PREPARE p3 FROM 'SET @@global.relay_log_purge = OFF'; PREPARE p4 FROM 'INSERT INTO tprep(truth) VALUES (@@global.relay_log_purge)'; PREPARE p5 FROM 'SET @@global.sync_binlog = 2000000'; PREPARE p6 FROM 'INSERT INTO tprep(num) VALUES (@@global.sync_binlog)'; PREPARE p7 FROM 'SET @@global.sync_binlog = 3000000'; PREPARE p8 FROM 'INSERT INTO tprep(num) VALUES (@@global.sync_binlog)'; PREPARE p9 FROM 'SET @@global.init_slave = \'SELECT 2\''; PREPARE p10 FROM 'INSERT INTO tprep(text) VALUES (@@global.init_slave)'; PREPARE p11 FROM 'SET @@global.init_slave = \'SELECT 3\''; PREPARE p12 FROM 'INSERT INTO tprep(text) VALUES (@@global.init_slave)'; PREPARE p13 FROM 'SET @@global.slave_exec_mode = \'IDEMPOTENT\''; PREPARE p14 FROM 'INSERT INTO tprep(text) VALUES (@@global.slave_exec_mode)'; PREPARE p15 FROM 'SET @@global.slave_exec_mode = \'STRICT\''; PREPARE p16 FROM 'INSERT INTO tprep(text) VALUES (@@global.slave_exec_mode)'; PREPARE p17 FROM 'SET @@sql_big_selects = ON'; PREPARE p18 FROM 'INSERT INTO tprep(truth) VALUES (@@sql_big_selects)'; PREPARE p19 FROM 'SET @@sql_big_selects = OFF'; PREPARE p20 FROM 'INSERT INTO tprep(truth) VALUES (@@sql_big_selects)'; PREPARE p21 FROM 'SET @@last_insert_id = 20'; PREPARE p22 FROM 'INSERT INTO tprep(num) VALUES (@@last_insert_id)'; PREPARE p23 FROM 'SET @@last_insert_id = 30'; PREPARE p24 FROM 'INSERT INTO tprep(num) VALUES (@@last_insert_id)'; PREPARE p25 FROM 'SET @@global.low_priority_updates = ON'; PREPARE p26 FROM 'SET @@local.low_priority_updates = OFF'; PREPARE p27 FROM 'INSERT INTO tprep(truth) VALUES (@@global.low_priority_updates)'; PREPARE p28 FROM 'INSERT INTO tprep(truth) VALUES (@@local.low_priority_updates)'; PREPARE p29 FROM 'SET @@global.low_priority_updates = OFF'; PREPARE p30 FROM 'SET @@local.low_priority_updates = ON'; PREPARE p31 FROM 'INSERT INTO tprep(truth) VALUES (@@global.low_priority_updates)'; PREPARE p32 FROM 'INSERT INTO tprep(truth) VALUES (@@local.low_priority_updates)'; PREPARE p33 FROM 'SET @@global.default_week_format = 3'; PREPARE p34 FROM 'SET @@local.default_week_format = 4'; PREPARE p35 FROM 'INSERT INTO tprep(num) VALUES (@@global.default_week_format)'; PREPARE p36 FROM 'INSERT INTO tprep(num) VALUES (@@local.default_week_format)'; PREPARE p37 FROM 'SET @@global.default_week_format = 5'; PREPARE p38 FROM 'SET @@local.default_week_format = 6'; PREPARE p39 FROM 'INSERT INTO tprep(num) VALUES (@@global.default_week_format)'; PREPARE p40 FROM 'INSERT INTO tprep(num) VALUES (@@local.default_week_format)'; PREPARE p41 FROM 'SET @@global.lc_time_names = \'sv_SE\''; PREPARE p42 FROM 'SET @@local.lc_time_names = \'sv_FI\''; PREPARE p43 FROM 'INSERT INTO tprep(text) VALUES (@@global.lc_time_names)'; PREPARE p44 FROM 'INSERT INTO tprep(text) VALUES (@@local.lc_time_names)'; PREPARE p45 FROM 'SET @@global.lc_time_names = \'ar_TN\''; PREPARE p46 FROM 'SET @@local.lc_time_names = \'ar_IQ\''; PREPARE p47 FROM 'INSERT INTO tprep(text) VALUES (@@global.lc_time_names)'; PREPARE p48 FROM 'INSERT INTO tprep(text) VALUES (@@local.lc_time_names)'; PREPARE p49 FROM 'SET @@global.sql_mode = \'\''; PREPARE p50 FROM 'SET @@local.sql_mode = \'IGNORE_SPACE,NO_AUTO_CREATE_USER\''; PREPARE p51 FROM 'INSERT INTO tprep(text) VALUES (@@global.sql_mode)'; PREPARE p52 FROM 'INSERT INTO tprep(text) VALUES (@@local.sql_mode)'; PREPARE p53 FROM 'SET @@global.sql_mode = \'NO_AUTO_VALUE_ON_ZERO,NO_BACKSLASH_ESCAPES,NO_DIR_IN_CREATE,NO_ENGINE_SUBSTITUTION\''; PREPARE p54 FROM 'SET @@local.sql_mode = \'NO_FIELD_OPTIONS,NO_KEY_OPTIONS,NO_TABLE_OPTIONS\''; PREPARE p55 FROM 'INSERT INTO tprep(text) VALUES (@@global.sql_mode)'; PREPARE p56 FROM 'INSERT INTO tprep(text) VALUES (@@local.sql_mode)'; PREPARE p57 FROM 'SET @user_num = 20'; PREPARE p58 FROM 'INSERT INTO tprep(num) VALUES (@user_num)'; PREPARE p59 FROM 'SET @user_num = 30'; PREPARE p60 FROM 'INSERT INTO tprep(num) VALUES (@user_num)'; PREPARE p61 FROM 'SET @user_text = \'Bergsbrunna\''; PREPARE p62 FROM 'INSERT INTO tprep(text) VALUES (@user_text)'; PREPARE p63 FROM 'SET @user_text = \'Centrum\''; PREPARE p64 FROM 'INSERT INTO tprep(text) VALUES (@user_text)'; EXECUTE p1; EXECUTE p2; EXECUTE p3; EXECUTE p4; EXECUTE p5; EXECUTE p6; EXECUTE p7; EXECUTE p8; EXECUTE p9; EXECUTE p10; EXECUTE p11; EXECUTE p12; EXECUTE p13; EXECUTE p14; EXECUTE p15; EXECUTE p16; EXECUTE p17; EXECUTE p18; EXECUTE p19; EXECUTE p20; EXECUTE p21; EXECUTE p22; EXECUTE p23; EXECUTE p24; EXECUTE p25; EXECUTE p26; EXECUTE p27; EXECUTE p28; EXECUTE p29; EXECUTE p30; EXECUTE p31; EXECUTE p32; EXECUTE p33; EXECUTE p34; EXECUTE p35; EXECUTE p36; EXECUTE p37; EXECUTE p38; EXECUTE p39; EXECUTE p40; EXECUTE p41; EXECUTE p42; EXECUTE p43; EXECUTE p44; EXECUTE p45; EXECUTE p46; EXECUTE p47; EXECUTE p48; EXECUTE p49; EXECUTE p50; EXECUTE p51; EXECUTE p52; EXECUTE p53; EXECUTE p54; EXECUTE p55; EXECUTE p56; EXECUTE p57; EXECUTE p58; EXECUTE p59; EXECUTE p60; EXECUTE p61; EXECUTE p62; EXECUTE p63; EXECUTE p64; include/sync_slave_sql_with_master.inc ==== Results ==== SELECT * FROM tstmt ORDER BY id; id truth num text 1 1 NULL NULL 2 0 NULL NULL 3 NULL 2000000 NULL 4 NULL 3000000 NULL 5 NULL NULL SELECT 2 6 NULL NULL SELECT 3 7 NULL NULL IDEMPOTENT 8 NULL NULL STRICT 9 1 NULL NULL 10 0 NULL NULL 11 NULL 20 NULL 12 NULL 30 NULL 13 1 NULL NULL 14 0 NULL NULL 15 0 NULL NULL 16 1 NULL NULL 17 NULL 3 NULL 18 NULL 4 NULL 19 NULL 5 NULL 20 NULL 6 NULL 21 NULL NULL sv_SE 22 NULL NULL sv_FI 23 NULL NULL ar_TN 24 NULL NULL ar_IQ 25 NULL NULL 26 NULL NULL IGNORE_SPACE,NO_AUTO_CREATE_USER 27 NULL NULL NO_DIR_IN_CREATE,NO_AUTO_VALUE_ON_ZERO,NO_BACKSLASH_ESCAPES,NO_ENGINE_SUBSTITUTION 28 NULL NULL NO_KEY_OPTIONS,NO_TABLE_OPTIONS,NO_FIELD_OPTIONS 29 NULL 20 NULL 30 NULL 30 NULL 31 NULL NULL Bergsbrunna 32 NULL NULL Centrum include/sync_slave_sql_with_master.inc include/diff_tables.inc [master:tstmt, master:tproc, master:tfunc, master:ttrig, master:tprep, slave:tstmt, slave:tproc, slave:tfunc, slave:ttrig, slave:tprep] ==== Clean up ==== [on master] DROP PROCEDURE proc; DROP FUNCTION func; DROP TRIGGER trig; DROP TABLE tstmt, tproc, tfunc, ttrig, tprep, trigger_table; SET @@global.default_week_format= @m_default_week_format; SET @@global.init_slave= @m_init_slave; SET @@global.lc_time_names= @m_lc_time_names; SET @@global.low_priority_updates= @m_low_priority_updates; SET @@global.relay_log_purge= @m_relay_log_purge; SET @@global.slave_exec_mode= @m_slave_exec_mode; SET @@global.sql_mode= @m_sql_mode; SET @@global.sync_binlog= @m_sync_binlog; [on slave] SET @@global.default_week_format= @s_default_week_format; SET @@global.init_slave= @s_init_slave; SET @@global.lc_time_names= @s_lc_time_names; SET @@global.low_priority_updates= @s_low_priority_updates; SET @@global.relay_log_purge= @s_relay_log_purge; SET @@global.slave_exec_mode= @s_slave_exec_mode; SET @@global.sql_mode= @s_sql_mode; SET @@global.sync_binlog= @s_sync_binlog; include/sync_slave_sql_with_master.inc include/rpl_end.inc