mirror of
https://github.com/MariaDB/server.git
synced 2025-05-05 16:59:35 +03:00
Normally, SET SESSION SQL_LOG_BIN is used by DBAs to run a non-conflicting command locally only, ensuring it does not get replicated. Setting GLOBAL SQL_LOG_BIN would not require all sessions to disconnect. When SQL_LOG_BIN is changed globally, it does not immediately take effect for any sessions. It takes effect by becoming the session-level default inherited at the start of each new session, and this setting is kept and cached for the duration of that session. Setting it intentionally is unlikely to have a useful effect under any circumstance; setting it unintentionally, such as while intending to use SET [SESSION] is potentially disastrous. Accidentally using SET GLOBAL SQL_LOG_BIN will not show an immediate effect to the user, instead not having the desired session-level effect, and thus causing other potential problems with local-only maintenance being binlogged and executed on slaves; And transactions from new sessions (after SQL_LOG_BIN is changed globally) are not binlogged and replicated, which would result in irrecoverable or difficult data loss. This is the regular GLOBAL variables way to work, but in replication context it does not look right on a working server (with connected sessions) 'set global sql_log_bin' and none of that connections is affected. Unexperienced DBA after noticing that the command did "nothing" will change the session var and most probably won't unset the global var, causing new sessions to not be binlog. Setting GLOBAL SQL_LOG_BIN allows DBA to stop binlogging on all new sessions, which can be used to make a server "replication read-only" without restarting the server. But this has such big requirements, stop all existing connections, that it is more likely to make a mess, it is too risky to allow the GLOBAL variable. The statement 'SET GLOBAL SQL_LOG_BIN=N' will produce an error in 5.5, 5.6 and 5.7. Reading the GLOBAL SQL_LOG_BIN will produce a deprecation warning in 5.7.
173 lines
7.4 KiB
Plaintext
173 lines
7.4 KiB
Plaintext
####################### mysql-test\t\sql_log_bin_basic.test ###################
|
||
# #
|
||
# Variable Name: sql_log_bin #
|
||
# Scope: SESSION #
|
||
# Access Type: Dynamic #
|
||
# Data Type: boolean #
|
||
# Default Value: #
|
||
# Valid Values: 0,1 #
|
||
# #
|
||
# #
|
||
# Creation Date: 2008-02-07 #
|
||
# Author: Rizwan #
|
||
# #
|
||
# Description: Test Cases of Dynamic System Variable sql_log_bin #
|
||
# that checks the behavior of this variable in the following ways#
|
||
# * Default Value #
|
||
# * Valid & Invalid values #
|
||
# * Scope & Access method #
|
||
# * Data Integrity #
|
||
# #
|
||
# Reference: http://dev.mysql.com/doc/refman/5.1/en/ #
|
||
# server-system-variables.html #
|
||
# #
|
||
###############################################################################
|
||
|
||
--source include/load_sysvars.inc
|
||
|
||
########################################################################
|
||
# START OF sql_log_bin TESTS #
|
||
########################################################################
|
||
|
||
|
||
##############################################################################
|
||
# Saving initial value of sql_log_bin in a temporary variable #
|
||
##############################################################################
|
||
|
||
SET @session_start_value = @@session.sql_log_bin;
|
||
SELECT @session_start_value;
|
||
|
||
--echo '#--------------------FN_DYNVARS_156_01------------------------#'
|
||
########################################################################
|
||
# Display the DEFAULT value of sql_log_bin #
|
||
########################################################################
|
||
|
||
SET @@session.sql_log_bin = 0;
|
||
SET @@session.sql_log_bin = DEFAULT;
|
||
SELECT @@session.sql_log_bin;
|
||
|
||
SET @@session.sql_log_bin = 1;
|
||
SET @@session.sql_log_bin = DEFAULT;
|
||
SELECT @@session.sql_log_bin;
|
||
|
||
|
||
--echo '#---------------------FN_DYNVARS_156_02-------------------------#'
|
||
#############################################################################
|
||
# Check if sql_log_bin can be accessed with and without @@ sign #
|
||
#############################################################################
|
||
|
||
SET sql_log_bin = 1;
|
||
SELECT @@sql_log_bin;
|
||
|
||
--Error ER_UNKNOWN_TABLE
|
||
SELECT session.sql_log_bin;
|
||
|
||
--Error ER_UNKNOWN_TABLE
|
||
SELECT local.sql_log_bin;
|
||
|
||
SET session sql_log_bin = 0;
|
||
SELECT @@session.sql_log_bin;
|
||
|
||
|
||
--echo '#--------------------FN_DYNVARS_156_03------------------------#'
|
||
########################################################################
|
||
# change the value of sql_log_bin to a valid value #
|
||
########################################################################
|
||
|
||
SET @@session.sql_log_bin = 0;
|
||
SELECT @@session.sql_log_bin;
|
||
SET @@session.sql_log_bin = 1;
|
||
SELECT @@session.sql_log_bin;
|
||
|
||
|
||
--echo '#--------------------FN_DYNVARS_156_04-------------------------#'
|
||
###########################################################################
|
||
# Change the value of sql_log_bin to invalid value #
|
||
###########################################################################
|
||
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = -1;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = 2;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = "T";
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = "Y";
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = TR<54>E;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = <20>N;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = OF;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = <20>FF;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = '<27>';
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@session.sql_log_bin = NO;
|
||
|
||
|
||
--echo '#-------------------FN_DYNVARS_156_05----------------------------#'
|
||
###########################################################################
|
||
# Test if setting global sql_log_bin gives error, #
|
||
# and there is no error on reading it. #
|
||
###########################################################################
|
||
|
||
SELECT @@global.sql_log_bin;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@global.sql_log_bin = 0;
|
||
SELECT @@global.sql_log_bin;
|
||
--Error ER_WRONG_VALUE_FOR_VAR
|
||
SET @@global.sql_log_bin = 1;
|
||
|
||
--echo '#----------------------FN_DYNVARS_156_06------------------------#'
|
||
#########################################################################
|
||
# Check if the value in GLOBAL Table contains variable value #
|
||
#########################################################################
|
||
|
||
SELECT count(VARIABLE_VALUE) FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES WHERE VARIABLE_NAME='sql_log_bin';
|
||
|
||
--echo '#----------------------FN_DYNVARS_156_07------------------------#'
|
||
#########################################################################
|
||
# Check if the value in GLOBAL Table matches value in variable #
|
||
#########################################################################
|
||
|
||
SELECT IF(@@session.sql_log_bin, "ON", "OFF") = VARIABLE_VALUE
|
||
FROM INFORMATION_SCHEMA.SESSION_VARIABLES
|
||
WHERE VARIABLE_NAME='sql_log_bin';
|
||
SELECT @@session.sql_log_bin;
|
||
SELECT VARIABLE_VALUE
|
||
FROM INFORMATION_SCHEMA.SESSION_VARIABLES
|
||
WHERE VARIABLE_NAME='sql_log_bin';
|
||
|
||
--echo '#---------------------FN_DYNVARS_156_08-------------------------#'
|
||
###################################################################
|
||
# Check if ON and OFF values can be used on variable #
|
||
###################################################################
|
||
|
||
SET @@session.sql_log_bin = OFF;
|
||
SELECT @@session.sql_log_bin;
|
||
SET @@session.sql_log_bin = ON;
|
||
SELECT @@session.sql_log_bin;
|
||
|
||
--echo '#---------------------FN_DYNVARS_156_09----------------------#'
|
||
###################################################################
|
||
# Check if TRUE and FALSE values can be used on variable #
|
||
###################################################################
|
||
|
||
SET @@session.sql_log_bin = TRUE;
|
||
SELECT @@session.sql_log_bin;
|
||
SET @@session.sql_log_bin = FALSE;
|
||
SELECT @@session.sql_log_bin;
|
||
|
||
##############################
|
||
# Restore initial value #
|
||
##############################
|
||
|
||
SET @@session.sql_log_bin = @session_start_value;
|
||
SELECT @@session.sql_log_bin;
|
||
|
||
###############################################################
|
||
# END OF sql_log_bin TESTS #
|
||
###############################################################
|