summaryrefslogtreecommitdiff
path: root/sql/sql_select.cc
diff options
context:
space:
mode:
Diffstat (limited to 'sql/sql_select.cc')
-rw-r--r--sql/sql_select.cc7
1 files changed, 7 insertions, 0 deletions
diff --git a/sql/sql_select.cc b/sql/sql_select.cc
index 7a1a7baaa1c..912f28d7168 100644
--- a/sql/sql_select.cc
+++ b/sql/sql_select.cc
@@ -590,6 +590,13 @@ void remove_redundant_subquery_clauses(st_select_lex *subq_select_lex)
DBUG_PRINT("info", ("DISTINCT removed"));
}
+ if (subq_select_lex->master_unit()->is_union_op_inside_in_predicate() &&
+ subq_select_lex->master_unit()->fake_select_lex == subq_select_lex &&
+ subq_select_lex->order_list.elements)
+ {
+ subq_select_lex->join->order= NULL;
+ }
+
/*
Remove GROUP BY if there are no aggregate functions and no HAVING
clause