summaryrefslogtreecommitdiff
path: root/sql/opt_table_elimination.cc
diff options
context:
space:
mode:
authorIgor Babaev <igor@askmonty.org>2011-04-26 19:58:41 -0700
committerIgor Babaev <igor@askmonty.org>2011-04-26 19:58:41 -0700
commit8d9dd21d85e257051b45b2f779dcd9bf696bf9e1 (patch)
tree8a848ea3c6c25075015261314a0f2e128dee4149 /sql/opt_table_elimination.cc
parentbbd4bb310d7b500a57be56b8f0501fa8eee6d40f (diff)
downloadmariadb-git-8d9dd21d85e257051b45b2f779dcd9bf696bf9e1.tar.gz
Fixed LP bugs #717577, #724942.
Both these two bugs happened due to the following problem. When a view column is referenced in the query an Item_direct_view_ref object is created that is refers to the Item_field for the column. All references to the same view column refer to the same Item_field. Different references can belong to different AND/OR levels and, as a result, can be included in different Item_equal object. These Item_equal objects may include different constant objects. If these constant objects are substituted for the Item_field created for a view column we have a conflict situation when the second substitution annuls the first substitution. This leads to wrong result sets returned by the query. Bug #724942 demonstrates such an erroneous behaviour. Test case of the bug #717577 produces wrong result sets because best equal fields of the multiple equalities built for different OR levels of the WHERE condition differs. The subsitution for the best equal field in the second OR branch overwrites the the substitution made for the first branch. To avoid such conflicts we have to substitute for the references to the view columns rather than for the underlying field items. To make such substitutions possible we have to include into multiple equalities references to view columns rather than field items created for such columns. This patch modifies the Item_equal class to include references to view columns into multiple equality objects. It also performs a clean up of the class methods and adds more comments. The methods of the Item_direct_view_ref class that assist substitutions for references to view columns has been also added by this patch.
Diffstat (limited to 'sql/opt_table_elimination.cc')
-rw-r--r--sql/opt_table_elimination.cc7
1 files changed, 4 insertions, 3 deletions
diff --git a/sql/opt_table_elimination.cc b/sql/opt_table_elimination.cc
index 7497395d628..c8c61720068 100644
--- a/sql/opt_table_elimination.cc
+++ b/sql/opt_table_elimination.cc
@@ -1208,15 +1208,16 @@ void build_eq_mods_for_cond(Dep_analysis_context *ctx,
if (!(fvl= new List<Dep_value_field>))
break; /* purecov: inspected */
- Item_equal_iterator it(*item_equal);
- Item_field *item;
+ Item_equal_fields_iterator it(*item_equal);
+ Item *item;
Item *bound_item= item_equal->get_const();
while ((item= it++))
{
+ Field *equal_field= it.get_curr_field();
if ((item->used_tables() & ctx->usable_tables))
{
Dep_value_field *field_val;
- if ((field_val= ctx->get_field_value(item->field)))
+ if ((field_val= ctx->get_field_value(equal_field)))
fvl->push_back(field_val);
}
else