Commit 213fc700 authored by Varun Gupta's avatar Varun Gupta

MDEV-10232: Scalar result of subquery changes after adding an outer select stmt

In a subquery, we don't have to maintain order
Added a fix such that order is considered when there is a limit clause.
parent 8a4d6055
...@@ -2442,3 +2442,15 @@ i ...@@ -2442,3 +2442,15 @@ i
drop table t1, t2, t3; drop table t1, t2, t3;
SET optimizer_switch= @@global.optimizer_switch; SET optimizer_switch= @@global.optimizer_switch;
set @@tmp_table_size= @@global.tmp_table_size; set @@tmp_table_size= @@global.tmp_table_size;
#
# MDEV-10232 Scalar result of subquery changes after adding an outer select stmt
#
create table t1(c1 int, c2 int, primary key(c2));
insert into t1 values(2,1),(1,2);
select (select c1 from t1 group by c1,c2 order by c1 limit 1) as x;
x
1
(select c1 from t1 group by c1,c2 order by c1 limit 1);
c1
1
drop table t1;
...@@ -1999,3 +1999,13 @@ drop table t1, t2, t3; ...@@ -1999,3 +1999,13 @@ drop table t1, t2, t3;
SET optimizer_switch= @@global.optimizer_switch; SET optimizer_switch= @@global.optimizer_switch;
set @@tmp_table_size= @@global.tmp_table_size; set @@tmp_table_size= @@global.tmp_table_size;
--echo #
--echo # MDEV-10232 Scalar result of subquery changes after adding an outer select stmt
--echo #
create table t1(c1 int, c2 int, primary key(c2));
insert into t1 values(2,1),(1,2);
select (select c1 from t1 group by c1,c2 order by c1 limit 1) as x;
(select c1 from t1 group by c1,c2 order by c1 limit 1);
drop table t1;
...@@ -1619,7 +1619,8 @@ JOIN::optimize_inner() ...@@ -1619,7 +1619,8 @@ JOIN::optimize_inner()
<fields> to ORDER BY <fields>. There are three exceptions: <fields> to ORDER BY <fields>. There are three exceptions:
- if skip_sort_order is set (see above), then we can simply skip - if skip_sort_order is set (see above), then we can simply skip
GROUP BY; GROUP BY;
- if we are in a subquery, we don't have to maintain order - if we are in a subquery, we don't have to maintain order unless there
is a limit clause in the subquery.
- we can only rewrite ORDER BY if the ORDER BY fields are 'compatible' - we can only rewrite ORDER BY if the ORDER BY fields are 'compatible'
with the GROUP BY ones, i.e. either one is a prefix of another. with the GROUP BY ones, i.e. either one is a prefix of another.
We only check if the ORDER BY is a prefix of GROUP BY. In this case We only check if the ORDER BY is a prefix of GROUP BY. In this case
...@@ -1631,7 +1632,7 @@ JOIN::optimize_inner() ...@@ -1631,7 +1632,7 @@ JOIN::optimize_inner()
if (!order || test_if_subpart(group_list, order)) if (!order || test_if_subpart(group_list, order))
{ {
if (skip_sort_order || if (skip_sort_order ||
select_lex->master_unit()->item) // This is a subquery (select_lex->master_unit()->item && select_limit == HA_POS_ERROR)) // This is a subquery
order= NULL; order= NULL;
else else
order= group_list; order= group_list;
......
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