Commit d998a163 authored by Sergey Petrunya's avatar Sergey Petrunya

MDEV-5045: Server crashes in QPF_query::print_explain with log_slow_verbosity='explain'

- Don't print a plan when the statement didn't produce it
- Also, add first testcase. We can't check the EXPLAIN from the slow log itself, though.
parent 2add4028
drop table if exists t0,t1;
create table t0 (a int);
insert into t0 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
explain select * from t0 where a < 3;
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t0 ALL NULL NULL NULL NULL 10 Using where
#
# MDEV-5045: Server crashes in QPF_query::print_explain with log_slow_verbosity='query_plan,explain'
#
set autocommit=1;
drop table t0;
--slow-query-log --long-query-time=0.00000 --log-slow-verbosity=query_plan,explain
#
# This is a test for EXPLAINs being written into slow query log.
# For now, we just run the queries and hope not to crash.
#
#
--disable_warnings
drop table if exists t0,t1;
--enable_warnings
create table t0 (a int);
insert into t0 values (0),(1),(2),(3),(4),(5),(6),(7),(8),(9);
explain select * from t0 where a < 3;
--echo #
--echo # MDEV-5045: Server crashes in QPF_query::print_explain with log_slow_verbosity='query_plan,explain'
--echo #
set autocommit=1;
drop table t0;
...@@ -2830,7 +2830,7 @@ bool MYSQL_QUERY_LOG::write(THD *thd, time_t current_time, ...@@ -2830,7 +2830,7 @@ bool MYSQL_QUERY_LOG::write(THD *thd, time_t current_time,
{ {
StringBuffer<128> buf; StringBuffer<128> buf;
DBUG_ASSERT(!thd->free_list); DBUG_ASSERT(!thd->free_list);
print_qpf_query(thd->lex, thd, &buf); if (!print_qpf_query(thd->lex, thd, &buf))
my_b_printf(&log_file, "%s", buf.c_ptr_safe()); my_b_printf(&log_file, "%s", buf.c_ptr_safe());
thd->free_items(); thd->free_items();
} }
......
...@@ -116,13 +116,15 @@ int QPF_query::print_explain(select_result_sink *output, ...@@ -116,13 +116,15 @@ int QPF_query::print_explain(select_result_sink *output,
{ {
/* Start printing from node with id=1 */ /* Start printing from node with id=1 */
QPF_node *node= get_node(1); QPF_node *node= get_node(1);
if (!node)
return 1; /* No query plan */
return node->print_explain(this, output, explain_flags); return node->print_explain(this, output, explain_flags);
} }
} }
void print_qpf_query(LEX *lex, THD *thd, String *str) bool print_qpf_query(LEX *lex, THD *thd, String *str)
{ {
lex->query_plan_footprint->print_explain_str(thd, str); return lex->query_plan_footprint->print_explain_str(thd, str);
} }
bool QPF_query::print_explain_str(THD *thd, String *out_str) bool QPF_query::print_explain_str(THD *thd, String *out_str)
...@@ -132,7 +134,8 @@ bool QPF_query::print_explain_str(THD *thd, String *out_str) ...@@ -132,7 +134,8 @@ bool QPF_query::print_explain_str(THD *thd, String *out_str)
select_result_text_buffer output_buf(thd); select_result_text_buffer output_buf(thd);
output_buf.send_result_set_metadata(fields, thd->lex->describe); output_buf.send_result_set_metadata(fields, thd->lex->describe);
print_explain(&output_buf, 0); if (print_explain(&output_buf, 0))
return true;
output_buf.save_to(out_str); output_buf.save_to(out_str);
return false; return false;
} }
......
...@@ -622,7 +622,7 @@ class QPF_query; ...@@ -622,7 +622,7 @@ class QPF_query;
void delete_qpf_query(LEX *lex); void delete_qpf_query(LEX *lex);
void create_qpf_query(LEX *lex, MEM_ROOT *mem_root); void create_qpf_query(LEX *lex, MEM_ROOT *mem_root);
void print_qpf_query(LEX *lex, THD *thd, String *str); bool print_qpf_query(LEX *lex, THD *thd, String *str);
class st_select_lex_unit: public st_select_lex_node { class st_select_lex_unit: public st_select_lex_node {
protected: protected:
......
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