mirror of
https://github.com/MariaDB/server.git
synced 2025-05-05 16:59:35 +03:00
assertion .\filesort.cc, line 797 A query with the "ORDER BY @@some_system_variable" clause, where @@some_system_variable is NULL, causes assertion failure in the filesort procedures. The reason of the failure is in the value of Item_func_get_system_var::maybe_null: it was unconditionally set to false even if the value of a variable was NULL. mysql-test/r/variables.result: Added test case for bug #42778. mysql-test/suite/sys_vars/r/innodb_data_home_dir_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/innodb_flush_method_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/rpl_init_slave_func.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/ssl_capath_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/r/ssl_cipher_basic.result: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/innodb_data_home_dir_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/innodb_flush_method_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/ssl_capath_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/suite/sys_vars/t/ssl_cipher_basic.test: Updated test case for bug #42778: system variables were NOT NULL, now they are nullable. mysql-test/t/variables.test: Added test case for bug #42778. sql/item.cc: Bug #42778: delete order by null global variable causes assertion .\filesort.cc, line 797 The longlong_from_string_with_check function has been modified to skip unwanted warnings: now it uses the THD::no_errors flag to suppress warnings. The Item_func_get_system_var::update_null_value method sets the no_error flag. sql/item_func.cc: Bug #42778: delete order by null global variable causes assertion .\filesort.cc, line 797 1. The Item_func_get_system_var::fix_length_and_dec method has been modified to make system variables truly nullable. 2. The Item_func_get_system_var::update_null_value method method has been overloaded with a simple wrapper (like Item_field::update_null_value) to suppress unwanted warnings from Item_func_get_system_var::val_int() calls on non-numeric variable values: the Item_func_get_system_var::update_null_value method sets and restores THD::no_errors flag for a nested call of the longlong_from_string_with_check function. sql/item_func.h: Bug #42778: delete order by null global variable causes assertion .\filesort.cc, line 797 The Item_func_get_system_var::update_null_value method method has been overloaded.
47 lines
1.3 KiB
Plaintext
47 lines
1.3 KiB
Plaintext
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;
|
|
connection slave
|
|
SET @start_max_connections= @@global.max_connections;
|
|
SET @start_init_slave= @@global.init_slave;
|
|
SET @@global.init_slave = 'SET @@global.max_connections = @@global.max_connections + 1';
|
|
DROP TABLE IF EXISTS t1;
|
|
CREATE TEMPORARY TABLE t1 AS SELECT @@global.init_slave AS my_column;
|
|
DESCRIBE t1;
|
|
Field Type Null Key Default Extra
|
|
my_column varchar(59) YES NULL
|
|
DROP TABLE t1;
|
|
SELECT @@global.init_slave = 'SET @@global.max_connections = @@global.max_connections + 1';
|
|
@@global.init_slave = 'SET @@global.max_connections = @@global.max_connections + 1'
|
|
1
|
|
Expect 1
|
|
SELECT @@global.max_connections= @start_max_connections;
|
|
@@global.max_connections= @start_max_connections
|
|
1
|
|
Expect 1
|
|
STOP SLAVE;
|
|
RESET MASTER;
|
|
RESET SLAVE;
|
|
START SLAVE;
|
|
SELECT @@global.max_connections = @start_max_connections + 1;
|
|
@@global.max_connections = @start_max_connections + 1
|
|
1
|
|
Expect 1
|
|
SET @@global.init_slave = "SET @a=5";
|
|
STOP SLAVE;
|
|
RESET MASTER;
|
|
RESET SLAVE;
|
|
START SLAVE;
|
|
SHOW VARIABLES LIKE 'init_slave';
|
|
Variable_name Value
|
|
init_slave SET @a=5
|
|
SELECT @a;
|
|
@a
|
|
NULL
|
|
Expect NULL
|
|
SET @@global.max_connections= @start_max_connections;
|
|
SET @@global.init_slave= @start_init_slave;
|