mirror of
https://github.com/MariaDB/server.git
synced 2025-01-21 06:22:28 +01:00
489ad44ab5
The code to get read the value of a system variable was extracting its value on PREPARE stage and was substituting the value (as a constant) into the parse tree. Note that this must be a reversible transformation, i.e. it must be reversed before each re-execution. Unfortunately this cannot be reliably done using the current code, because there are other non-reversible source tree transformations that can interfere with this reversible transformation. Fixed by not resolving the value at PREPARE, but at EXECUTE (as the rest of the functions operate). Added a cache of the value (so that it's constant throughout the execution of the query). Note that the cache also caches NULL values. Updated an obsolete related test suite (variables-big) and the code to test the result type of system variables (as per bug 74).
53 lines
1.6 KiB
Text
53 lines
1.6 KiB
Text
'#---------------------BS_STVARS_048_01----------------------#'
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
COUNT(@@GLOBAL.ssl_cipher)
|
|
1
|
|
1 Expected
|
|
'#---------------------BS_STVARS_048_02----------------------#'
|
|
SET @@GLOBAL.ssl_cipher=1;
|
|
ERROR HY000: Variable 'ssl_cipher' is a read only variable
|
|
Expected error 'Read only variable'
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
COUNT(@@GLOBAL.ssl_cipher)
|
|
1
|
|
1 Expected
|
|
'#---------------------BS_STVARS_048_03----------------------#'
|
|
SELECT @@GLOBAL.ssl_cipher = VARIABLE_VALUE
|
|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
|
|
WHERE VARIABLE_NAME='ssl_cipher';
|
|
@@GLOBAL.ssl_cipher = VARIABLE_VALUE
|
|
NULL
|
|
1 Expected
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
COUNT(@@GLOBAL.ssl_cipher)
|
|
1
|
|
1 Expected
|
|
SELECT COUNT(VARIABLE_VALUE)
|
|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
|
|
WHERE VARIABLE_NAME='ssl_cipher';
|
|
COUNT(VARIABLE_VALUE)
|
|
1
|
|
1 Expected
|
|
'#---------------------BS_STVARS_048_04----------------------#'
|
|
SELECT @@ssl_cipher = @@GLOBAL.ssl_cipher;
|
|
@@ssl_cipher = @@GLOBAL.ssl_cipher
|
|
NULL
|
|
1 Expected
|
|
'#---------------------BS_STVARS_048_05----------------------#'
|
|
SELECT COUNT(@@ssl_cipher);
|
|
COUNT(@@ssl_cipher)
|
|
1
|
|
1 Expected
|
|
SELECT COUNT(@@local.ssl_cipher);
|
|
ERROR HY000: Variable 'ssl_cipher' is a GLOBAL variable
|
|
Expected error 'Variable is a GLOBAL variable'
|
|
SELECT COUNT(@@SESSION.ssl_cipher);
|
|
ERROR HY000: Variable 'ssl_cipher' is a GLOBAL variable
|
|
Expected error 'Variable is a GLOBAL variable'
|
|
SELECT COUNT(@@GLOBAL.ssl_cipher);
|
|
COUNT(@@GLOBAL.ssl_cipher)
|
|
1
|
|
1 Expected
|
|
SELECT ssl_cipher = @@SESSION.ssl_cipher;
|
|
ERROR 42S22: Unknown column 'ssl_cipher' in 'field list'
|
|
Expected error 'Readonly variable'
|