Commit be55bbc2 authored by Sergei Golubchik's avatar Sergei Golubchik

MDEV-7826 Server crashes in Item_subselect::enumerate_field_refs_processor

upper->item can be NULL if we're referring to an aggregate function
parent c5975eae
...@@ -2531,3 +2531,17 @@ select a from t1 group by a having a > 1; ...@@ -2531,3 +2531,17 @@ select a from t1 group by a having a > 1;
a a
drop table t1; drop table t1;
set sql_mode= @save_sql_mode; set sql_mode= @save_sql_mode;
create table t1 (f1 int);
insert into t1 values (5),(9);
create table t2 (f2 int);
insert into t2 values (0),(6);
create table t3 (f3 int);
insert into t3 values (6),(3);
create table t4 (f4 int);
insert into t4 values (1),(0);
select
(select min(f1) from t1 where f1 in (select min(f4) from t2)) as field7,
(select count(*) from t3 where f3 in (select max(f4) from t2 group by field7))
from t4;
ERROR 42S22: Reference 'field7' not supported (reference to group function)
drop table t1, t2, t3, t4;
...@@ -1703,6 +1703,25 @@ select a as x from t1 group by x having x > 1; ...@@ -1703,6 +1703,25 @@ select a as x from t1 group by x having x > 1;
select a from t1 group by a having a > 1; select a from t1 group by a having a > 1;
drop table t1; drop table t1;
set sql_mode= @save_sql_mode; set sql_mode= @save_sql_mode;
#
# MDEV-7826 Server crashes in Item_subselect::enumerate_field_refs_processor
#
create table t1 (f1 int);
insert into t1 values (5),(9);
create table t2 (f2 int);
insert into t2 values (0),(6);
create table t3 (f3 int);
insert into t3 values (6),(3);
create table t4 (f4 int);
insert into t4 values (1),(0);
--error ER_ILLEGAL_REFERENCE
select
(select min(f1) from t1 where f1 in (select min(f4) from t2)) as field7,
(select count(*) from t3 where f3 in (select max(f4) from t2 group by field7))
from t4;
drop table t1, t2, t3, t4;
# #
# End of MariaDB 5.5 tests # End of MariaDB 5.5 tests
# #
...@@ -316,7 +316,8 @@ bool Item_subselect::enumerate_field_refs_processor(uchar *arg) ...@@ -316,7 +316,8 @@ bool Item_subselect::enumerate_field_refs_processor(uchar *arg)
while ((upper= it++)) while ((upper= it++))
{ {
if (upper->item->walk(&Item::enumerate_field_refs_processor, FALSE, arg)) if (upper->item &&
upper->item->walk(&Item::enumerate_field_refs_processor, FALSE, arg))
return TRUE; return TRUE;
} }
return FALSE; return FALSE;
......
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