summaryrefslogtreecommitdiff
path: root/sql/sql_cte.cc
diff options
context:
space:
mode:
authorIgor Babaev <igor@askmonty.org>2018-02-05 10:47:59 -0800
committerIgor Babaev <igor@askmonty.org>2018-02-05 10:48:28 -0800
commit465979eabfe3acacc0566fa93402e449e1a9f476 (patch)
tree716f2a7512025b924eedaf00baaf2dd049f8afed /sql/sql_cte.cc
parent217fc122c8e893aa48fa5dcfb3dbfcc99a2aa299 (diff)
downloadmariadb-git-465979eabfe3acacc0566fa93402e449e1a9f476.tar.gz
Fixed mdev-15119 CTE, referencing another CTE, that is declared after,
does not return error Corrected the code of st_select_lex::find_table_def_in_with_clauses() for a proper identification of CTE references used in embedded CTEs.
Diffstat (limited to 'sql/sql_cte.cc')
-rw-r--r--sql/sql_cte.cc26
1 files changed, 15 insertions, 11 deletions
diff --git a/sql/sql_cte.cc b/sql/sql_cte.cc
index a67337433fa..a53e6b07813 100644
--- a/sql/sql_cte.cc
+++ b/sql/sql_cte.cc
@@ -1006,23 +1006,20 @@ bool With_element::is_anchor(st_select_lex *sel)
With_element *st_select_lex::find_table_def_in_with_clauses(TABLE_LIST *table)
{
- st_select_lex_unit *master_unit= NULL;
With_element *found= NULL;
- for (st_select_lex *sl= this;
- sl;
- sl= master_unit->outer_select())
+ st_select_lex_unit *master_unit;
+ st_select_lex *outer_sl;
+ for (st_select_lex *sl= this; sl; sl= outer_sl)
{
- With_element *with_elem= sl->get_with_element();
/*
If sl->master_unit() is the spec of a with element then the search for
a definition was already done by With_element::check_dependencies_in_spec
and it was unsuccesful. Yet for units cloned from the spec it has not
been done yet.
*/
- With_clause *attached_with_clause=sl->get_with_clause();
- if (attached_with_clause &&
- (found= attached_with_clause->find_table_def(table, NULL)))
- break;
+ master_unit= sl->master_unit();
+ outer_sl= master_unit->outer_select();
+ With_element *with_elem= sl->get_with_element();
if (with_elem)
{
With_clause *containing_with_clause= with_elem->get_owner();
@@ -1030,9 +1027,16 @@ With_element *st_select_lex::find_table_def_in_with_clauses(TABLE_LIST *table)
NULL : with_elem;
if ((found= containing_with_clause->find_table_def(table, barrier)))
break;
- sl= sl->master_unit()->outer_select();
+ if (outer_sl && !outer_sl->get_with_element())
+ break;
+ }
+ else
+ {
+ With_clause *attached_with_clause= sl->get_with_clause();
+ if (attached_with_clause &&
+ (found= attached_with_clause->find_table_def(table, NULL)))
+ break;
}
- master_unit= sl->master_unit();
/* Do not look for the table's definition beyond the scope of the view */
if (master_unit->is_view)
break;