From f2033df6ac0f64664d9aad2d56fdd74f4bf9d666 Mon Sep 17 00:00:00 2001 From: Igor Babaev Date: Thu, 24 Aug 2017 20:49:07 -0700 Subject: More thorough correction of the patch that complemented the patch for mdev-10855 --- sql/sql_window.cc | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) (limited to 'sql/sql_window.cc') diff --git a/sql/sql_window.cc b/sql/sql_window.cc index 40197be569f..33e5464e659 100644 --- a/sql/sql_window.cc +++ b/sql/sql_window.cc @@ -334,12 +334,12 @@ ORDER *st_select_lex::find_common_window_func_partition_fields(THD *thd) Item *item; DBUG_ASSERT(window_funcs.elements); List_iterator_fast it(window_funcs); - Item_window_func *wf= it++; - if (!wf->window_spec->partition_list) + Item_window_func *first_wf= it++; + if (!first_wf->window_spec->partition_list) return 0; List common_fields; uint first_partition_elements= 0; - for (ord= wf->window_spec->partition_list->first; ord; ord= ord->next) + for (ord= first_wf->window_spec->partition_list->first; ord; ord= ord->next) { if ((*ord->item)->real_item()->type() == Item::FIELD_ITEM) common_fields.push_back(*ord->item, thd->mem_root); @@ -347,8 +347,9 @@ ORDER *st_select_lex::find_common_window_func_partition_fields(THD *thd) } if (window_specs.elements == 1 && common_fields.elements == first_partition_elements) - return wf->window_spec->partition_list->first; + return first_wf->window_spec->partition_list->first; List_iterator li(common_fields); + Item_window_func *wf; while (common_fields.elements && (wf= it++)) { if (!wf->window_spec->partition_list) @@ -368,11 +369,9 @@ ORDER *st_select_lex::find_common_window_func_partition_fields(THD *thd) if (!common_fields.elements) return 0; if (common_fields.elements == first_partition_elements) - return wf->window_spec->partition_list->first; + return first_wf->window_spec->partition_list->first; SQL_I_List res_list; - it.rewind(); - wf= it++; - for (ord= wf->window_spec->partition_list->first, item= li++; + for (ord= first_wf->window_spec->partition_list->first, item= li++; ord; ord= ord->next) { if (item != *ord->item) -- cgit v1.2.1