mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-03 14:33:32 +03:00 
			
		
		
		
	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).
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
'#---------------------BS_STVARS_029_01----------------------#'
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
COUNT(@@GLOBAL.innodb_flush_method)
 | 
						|
1
 | 
						|
1 Expected
 | 
						|
'#---------------------BS_STVARS_029_02----------------------#'
 | 
						|
SET @@GLOBAL.innodb_flush_method=1;
 | 
						|
ERROR HY000: Variable 'innodb_flush_method' is a read only variable
 | 
						|
Expected error 'Read only variable'
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
COUNT(@@GLOBAL.innodb_flush_method)
 | 
						|
1
 | 
						|
1 Expected
 | 
						|
'#---------------------BS_STVARS_029_03----------------------#'
 | 
						|
SELECT @@GLOBAL.innodb_flush_method = VARIABLE_VALUE
 | 
						|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
 | 
						|
WHERE VARIABLE_NAME='innodb_flush_method';
 | 
						|
@@GLOBAL.innodb_flush_method = VARIABLE_VALUE
 | 
						|
NULL
 | 
						|
1 Expected
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
COUNT(@@GLOBAL.innodb_flush_method)
 | 
						|
1
 | 
						|
1 Expected
 | 
						|
SELECT COUNT(VARIABLE_VALUE)
 | 
						|
FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES 
 | 
						|
WHERE VARIABLE_NAME='innodb_flush_method';
 | 
						|
COUNT(VARIABLE_VALUE)
 | 
						|
1
 | 
						|
1 Expected
 | 
						|
'#---------------------BS_STVARS_029_04----------------------#'
 | 
						|
SELECT @@innodb_flush_method = @@GLOBAL.innodb_flush_method;
 | 
						|
@@innodb_flush_method = @@GLOBAL.innodb_flush_method
 | 
						|
NULL
 | 
						|
1 Expected
 | 
						|
'#---------------------BS_STVARS_029_05----------------------#'
 | 
						|
SELECT COUNT(@@innodb_flush_method);
 | 
						|
COUNT(@@innodb_flush_method)
 | 
						|
1
 | 
						|
1 Expected
 | 
						|
SELECT COUNT(@@local.innodb_flush_method);
 | 
						|
ERROR HY000: Variable 'innodb_flush_method' is a GLOBAL variable
 | 
						|
Expected error 'Variable is a GLOBAL variable'
 | 
						|
SELECT COUNT(@@SESSION.innodb_flush_method);
 | 
						|
ERROR HY000: Variable 'innodb_flush_method' is a GLOBAL variable
 | 
						|
Expected error 'Variable is a GLOBAL variable'
 | 
						|
SELECT COUNT(@@GLOBAL.innodb_flush_method);
 | 
						|
COUNT(@@GLOBAL.innodb_flush_method)
 | 
						|
1
 | 
						|
1 Expected
 | 
						|
SELECT innodb_flush_method = @@SESSION.innodb_flush_method;
 | 
						|
ERROR 42S22: Unknown column 'innodb_flush_method' in 'field list'
 | 
						|
Expected error 'Readonly variable'
 |