Commit b503d77d authored by Tor Didriksen's avatar Tor Didriksen

Backport of fix for Bug#52123

parent ed74edad
...@@ -1739,6 +1739,16 @@ SELECT RELEASE_LOCK('aaaaaaaaaaaaaaaaa'); ...@@ -1739,6 +1739,16 @@ SELECT RELEASE_LOCK('aaaaaaaaaaaaaaaaa');
# #
End of 5.1 tests End of 5.1 tests
# #
# Bug#52123 Assertion failed: aggregator == aggr->Aggrtype(),
# file .\item_sum.cc, line 587
#
CREATE TABLE t1(a int, KEY(a));
INSERT INTO t1 VALUES (1), (2);
SELECT 1 FROM t1 ORDER BY AVG(DISTINCT a);
1
1
DROP TABLE t1;
#
# Bug#55648: Server crash on MIN/MAX on maximum time value # Bug#55648: Server crash on MIN/MAX on maximum time value
# #
CREATE TABLE t1(c1 TIME NOT NULL); CREATE TABLE t1(c1 TIME NOT NULL);
......
...@@ -1120,6 +1120,17 @@ SELECT RELEASE_LOCK('aaaaaaaaaaaaaaaaa'); ...@@ -1120,6 +1120,17 @@ SELECT RELEASE_LOCK('aaaaaaaaaaaaaaaaa');
--echo # --echo #
--echo End of 5.1 tests --echo End of 5.1 tests
###
--echo #
--echo # Bug#52123 Assertion failed: aggregator == aggr->Aggrtype(),
--echo # file .\item_sum.cc, line 587
--echo #
CREATE TABLE t1(a int, KEY(a));
INSERT INTO t1 VALUES (1), (2);
SELECT 1 FROM t1 ORDER BY AVG(DISTINCT a);
DROP TABLE t1;
--echo # --echo #
--echo # Bug#55648: Server crash on MIN/MAX on maximum time value --echo # Bug#55648: Server crash on MIN/MAX on maximum time value
--echo # --echo #
......
...@@ -556,24 +556,27 @@ Item *Item_sum::set_arg(uint i, THD *thd, Item *new_val) ...@@ -556,24 +556,27 @@ Item *Item_sum::set_arg(uint i, THD *thd, Item *new_val)
int Item_sum::set_aggregator(Aggregator::Aggregator_type aggregator) int Item_sum::set_aggregator(Aggregator::Aggregator_type aggregator)
{ {
if (aggr) /*
Dependent subselects may be executed multiple times, making
set_aggregator to be called multiple times. The aggregator type
will be the same, but it needs to be reset so that it is
reevaluated with the new dependent data.
This function may also be called multiple times during query optimization.
In this case, the type may change, so we delete the old aggregator,
and create a new one.
*/
if (aggr && aggregator == aggr->Aggrtype())
{ {
/*
Dependent subselects may be executed multiple times, making
set_aggregator to be called multiple times. The aggregator type
will be the same, but it needs to be reset so that it is
reevaluated with the new dependent data.
*/
DBUG_ASSERT(aggregator == aggr->Aggrtype());
aggr->clear(); aggr->clear();
return FALSE; return FALSE;
} }
delete aggr;
switch (aggregator) switch (aggregator)
{ {
case Aggregator::DISTINCT_AGGREGATOR: case Aggregator::DISTINCT_AGGREGATOR:
aggr= new Aggregator_distinct(this); aggr= new Aggregator_distinct(this);
break; break;
case Aggregator::SIMPLE_AGGREGATOR: case Aggregator::SIMPLE_AGGREGATOR:
aggr= new Aggregator_simple(this); aggr= new Aggregator_simple(this);
break; break;
......
...@@ -461,10 +461,9 @@ public: ...@@ -461,10 +461,9 @@ public:
*/ */
virtual void no_rows_in_result() virtual void no_rows_in_result()
{ {
if (!aggr) set_aggregator(with_distinct ?
set_aggregator(with_distinct ? Aggregator::DISTINCT_AGGREGATOR :
Aggregator::DISTINCT_AGGREGATOR : Aggregator::SIMPLE_AGGREGATOR);
Aggregator::SIMPLE_AGGREGATOR);
aggregator_clear(); aggregator_clear();
} }
virtual void make_unique() { force_copy_fields= TRUE; } virtual void make_unique() { force_copy_fields= TRUE; }
...@@ -515,11 +514,10 @@ public: ...@@ -515,11 +514,10 @@ public:
quick_group= with_distinct ? 0 : 1; quick_group= with_distinct ? 0 : 1;
} }
/** /*
Set the type of aggregation : DISTINCT or not. Set the type of aggregation : DISTINCT or not.
Called when the final determination is done about the aggregation May be called multiple times.
type and the object is about to be used.
*/ */
int set_aggregator(Aggregator::Aggregator_type aggregator); int set_aggregator(Aggregator::Aggregator_type aggregator);
......
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