mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 01:04:19 +01:00
02e38e2ece
Improve performance of queries like SELECT * FROM t1 WHERE field = NAME_CONST('a', 4); by, in this example, replacing the WHERE clause with field = 4 in the case of ref access. The rewrite is done during fix_fields and we disambiguate this case from other cases of NAME_CONST by inspecting where we are in parsing. We rely on THD::where to accomplish this. To improve performance there, we change the type of THD::where to be an enumeration, so we can avoid string comparisons during Item_name_const::fix_fields. Consequently, this patch also changes all usages of THD::where to conform likewise.
87 lines
1.8 KiB
Text
87 lines
1.8 KiB
Text
create table t1 (a int, b int);
|
|
insert into t1 values (1,1),(2,2);
|
|
explain format=json
|
|
select * from t1 where a=name_const('varname',1);
|
|
EXPLAIN
|
|
{
|
|
"query_block": {
|
|
"select_id": 1,
|
|
"table": {
|
|
"table_name": "t1",
|
|
"access_type": "ALL",
|
|
"rows": 2,
|
|
"filtered": 100,
|
|
"attached_condition": "t1.a = 1"
|
|
}
|
|
}
|
|
}
|
|
explain format=json
|
|
select * from t1 left join t1 as t2 on t1.a=name_const('varname',1) and t1.b=t2.b;
|
|
EXPLAIN
|
|
{
|
|
"query_block": {
|
|
"select_id": 1,
|
|
"const_condition": "1",
|
|
"table": {
|
|
"table_name": "t1",
|
|
"access_type": "ALL",
|
|
"rows": 2,
|
|
"filtered": 100
|
|
},
|
|
"block-nl-join": {
|
|
"table": {
|
|
"table_name": "t2",
|
|
"access_type": "ALL",
|
|
"rows": 2,
|
|
"filtered": 100
|
|
},
|
|
"buffer_type": "flat",
|
|
"buffer_size": "141",
|
|
"join_type": "BNL",
|
|
"attached_condition": "trigcond(t2.b = t1.b and trigcond(t1.a = 1))"
|
|
}
|
|
}
|
|
}
|
|
create table t2 (
|
|
a varchar(100) collate utf8_unicode_ci,
|
|
b int
|
|
);
|
|
insert into t2 values ('foo', 1),('bar', 1);
|
|
create procedure p1(var1 varchar(10))
|
|
update t2 set b=b+1 where a=var1;
|
|
call p1('foo');
|
|
call p1('foo');
|
|
call p1('foo');
|
|
select * from t2;
|
|
a b
|
|
foo 4
|
|
bar 1
|
|
create table t3 (
|
|
a varchar(100) collate utf8_unicode_ci,
|
|
b int
|
|
);
|
|
insert into t3 values ('foo', 1),('bar', 1);
|
|
select * from t3;
|
|
a b
|
|
foo 1
|
|
bar 1
|
|
explain format=json
|
|
update t3 set b=b+1 where a= NAME_CONST('var1',_latin1'foo' COLLATE 'latin1_swedish_ci');
|
|
EXPLAIN
|
|
{
|
|
"query_block": {
|
|
"select_id": 1,
|
|
"table": {
|
|
"update": 1,
|
|
"table_name": "t3",
|
|
"access_type": "ALL",
|
|
"rows": 2,
|
|
"attached_condition": "t3.a = convert(_latin1'foo' collate latin1_swedish_ci using utf8mb3)"
|
|
}
|
|
}
|
|
}
|
|
select * from t3 where a= NAME_CONST('var1',_latin1'foo' COLLATE 'latin1_swedish_ci');
|
|
a b
|
|
foo 1
|
|
drop procedure p1;
|
|
drop table t1, t2, t3;
|