Commit 517e9334 authored by Sergei Petrunia's avatar Sergei Petrunia

MDEV-22891: Optimizer trace: const tables are not clearly visible

Make mark_join_nest_as_const() print its action into the trace.
parent c9f5cb97
...@@ -8530,5 +8530,36 @@ select count(*) from seq_1_to_10000000 { ...@@ -8530,5 +8530,36 @@ select count(*) from seq_1_to_10000000 {
} }
] ]
} 0 0 } 0 0
#
# MDEV-22891: Optimizer trace: const tables are not clearly visible
#
create table t0(a int primary key);
insert into t0 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
create table t1 (pk int primary key, a int);
insert into t1 select a,a from t0;
create table t2 (pk int primary key, a int);
insert into t2 select a,a from t0;
create table t3 (pk int primary key, a int);
insert into t3 select a,a from t0;
explain
select * from t1 left join (t2 join t3 on t3.pk=1000) on t2.a=t1.a and t2.pk is null;
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t3 const PRIMARY NULL NULL NULL 1 Impossible ON condition
1 SIMPLE t2 const PRIMARY NULL NULL NULL 1 Impossible ON condition
1 SIMPLE t1 ALL NULL NULL NULL NULL 10
select JSON_DETAILED(JSON_EXTRACT(trace, '$**.mark_join_nest_as_const'))
from information_schema.optimizer_trace;
JSON_DETAILED(JSON_EXTRACT(trace, '$**.mark_join_nest_as_const'))
[
{
"members":
[
"t3",
"t2"
]
}
]
drop table t0, t1, t2, t3;
# End of 10.5 tests # End of 10.5 tests
set optimizer_trace='enabled=off'; set optimizer_trace='enabled=off';
...@@ -604,5 +604,28 @@ DROP TABLE t1,t2; ...@@ -604,5 +604,28 @@ DROP TABLE t1,t2;
select count(*) from seq_1_to_10000000; select count(*) from seq_1_to_10000000;
select * from INFORMATION_SCHEMA.OPTIMIZER_TRACE; select * from INFORMATION_SCHEMA.OPTIMIZER_TRACE;
--echo #
--echo # MDEV-22891: Optimizer trace: const tables are not clearly visible
--echo #
create table t0(a int primary key);
insert into t0 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
create table t1 (pk int primary key, a int);
insert into t1 select a,a from t0;
create table t2 (pk int primary key, a int);
insert into t2 select a,a from t0;
create table t3 (pk int primary key, a int);
insert into t3 select a,a from t0;
explain
select * from t1 left join (t2 join t3 on t3.pk=1000) on t2.a=t1.a and t2.pk is null;
select JSON_DETAILED(JSON_EXTRACT(trace, '$**.mark_join_nest_as_const'))
from information_schema.optimizer_trace;
drop table t0, t1, t2, t3;
--echo # End of 10.5 tests --echo # End of 10.5 tests
set optimizer_trace='enabled=off'; set optimizer_trace='enabled=off';
...@@ -4737,6 +4737,10 @@ void mark_join_nest_as_const(JOIN *join, ...@@ -4737,6 +4737,10 @@ void mark_join_nest_as_const(JOIN *join,
{ {
List_iterator<TABLE_LIST> it(join_nest->nested_join->join_list); List_iterator<TABLE_LIST> it(join_nest->nested_join->join_list);
TABLE_LIST *tbl; TABLE_LIST *tbl;
Json_writer_object emb_obj(join->thd);
Json_writer_object trace_obj(join->thd, "mark_join_nest_as_const");
Json_writer_array trace_array(join->thd, "members");
while ((tbl= it++)) while ((tbl= it++))
{ {
if (tbl->nested_join) if (tbl->nested_join)
...@@ -4756,6 +4760,8 @@ void mark_join_nest_as_const(JOIN *join, ...@@ -4756,6 +4760,8 @@ void mark_join_nest_as_const(JOIN *join,
*found_const_table_map|= tab->table->map; *found_const_table_map|= tab->table->map;
set_position(join,(*const_count)++,tab,(KEYUSE*) 0); set_position(join,(*const_count)++,tab,(KEYUSE*) 0);
mark_as_null_row(tab->table); // All fields are NULL mark_as_null_row(tab->table); // All fields are NULL
trace_array.add_table_name(tab->table);
} }
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment