mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 01:18:31 +02:00 
			
		
		
		
	 e987b9350c
			
		
	
	
	e987b9350c
	
	
	
		
			
			(Review input addressed)
(Added handling of UPDATE/DELETE and partitioning w/o index)
If the properties of the used collation allow, do the following
equivalent rewrites:
1. UPPER(key_col)=expr  ->  key_col=expr
   expr=UPPER(key_col)  ->  expr=key_col
   (also rewrite both sides of the equality at the same time)
2. UPPER(key_col) IN (constant-list)  -> key_col IN (constant-list)
- Mark utf8mb{3,4}_general_ci as collations that allow this.
- Add optimizer_switch='sargable_casefold=ON' to control this.
  (ON by default in this patch)
- Cover the rewrite in Optimizer Trace, rewrite name is
  "sargable_casefold_removal".
		
	
			
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| create table t1 (
 | |
| col1 varchar(32), 
 | |
| col2 varchar(32), 
 | |
| key(col1),
 | |
| key(col2)
 | |
| ) collate utf8mb3_general_ci;
 | |
| insert into t1
 | |
| select 
 | |
| concat('A-', seq),
 | |
| concat('A-', seq)
 | |
| from seq_1_to_100;
 | |
| set
 | |
| @tmp_ot= @@optimizer_trace,
 | |
| @tmp_os=@@optimizer_switch,
 | |
| optimizer_switch='sargable_casefold=on',
 | |
| optimizer_trace=1;
 | |
| explain select * from t1 where 'abc'=upper(col1);
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	SIMPLE	t1	ref	col1	col1	99	const	1	Using index condition
 | |
| select 
 | |
| json_detailed(json_extract(trace, '$**.sargable_casefold_removal')) as JS
 | |
| from information_schema.optimizer_trace;
 | |
| JS
 | |
| [
 | |
|     {
 | |
|         "before": "'abc' = ucase(t1.col1)",
 | |
|         "after": "'abc' = t1.col1"
 | |
|     }
 | |
| ]
 | |
| explain select * from t1 where ucase(col2)=upper(col1);
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	SIMPLE	t1	ALL	NULL	NULL	NULL	NULL	100	Using where
 | |
| select 
 | |
| json_detailed(json_extract(trace, '$**.sargable_casefold_removal')) as JS
 | |
| from information_schema.optimizer_trace;
 | |
| JS
 | |
| [
 | |
|     {
 | |
|         "before": "ucase(t1.col2) = ucase(t1.col1)",
 | |
|         "after": "t1.col2 = t1.col1"
 | |
|     }
 | |
| ]
 | |
| explain
 | |
| select * from t1 where upper(col1) IN ('A-3','A-4','a-5');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	SIMPLE	t1	range	col1	col1	99	NULL	3	Using index condition
 | |
| # Will show the rewrite:
 | |
| select 
 | |
| json_detailed(json_extract(trace, '$**.sargable_casefold_removal')) as JS
 | |
| from information_schema.optimizer_trace;
 | |
| JS
 | |
| [
 | |
|     {
 | |
|         "before": "ucase(t1.col1) in ('A-3','A-4','a-5')",
 | |
|         "after": "t1.col1 in ('A-3','A-4','a-5')"
 | |
|     }
 | |
| ]
 | |
| set 
 | |
| optimizer_trace=@tmp_ot,
 | |
| optimizer_switch=@tmp_os;
 | |
| drop table t1;
 |