You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-07-29 08:21:15 +03:00
fix(plugin): MCOL-5236 Take Item
from Ref_Item
for group by list. (#3162)
This commit is contained in:
@ -498,9 +498,18 @@ bool sortItemIsInGrouping(Item* sort_item, ORDER* groupcol)
|
||||
// is either Field or Func
|
||||
// Consider nonConstFunc() check here
|
||||
if (!found && sort_item->type() == Item::FUNC_ITEM &&
|
||||
(group_item->type() == Item::FUNC_ITEM || group_item->type() == Item::FIELD_ITEM))
|
||||
(group_item->type() == Item::FUNC_ITEM || group_item->type() == Item::FIELD_ITEM ||
|
||||
group_item->type() == Item::REF_ITEM))
|
||||
{
|
||||
found = sortItemIsInGroupRec(sort_item, group_item);
|
||||
// MCOL-5236: see @bug5993 and @bug5916.
|
||||
Item* item = group_item;
|
||||
while (item->type() == Item::REF_ITEM)
|
||||
{
|
||||
Item_ref* item_ref = static_cast<Item_ref*>(item);
|
||||
item = *item_ref->ref;
|
||||
}
|
||||
|
||||
found = sortItemIsInGroupRec(sort_item, item);
|
||||
}
|
||||
}
|
||||
|
||||
@ -4387,7 +4396,8 @@ ReturnedColumn* buildFunctionColumn(Item_func* ifp, gp_walk_info& gwi, bool& non
|
||||
|
||||
// A few functions use a different collation than that found in
|
||||
// the base ifp class
|
||||
if (funcName == "locate" || funcName == "find_in_set" || funcName == "strcmp" || funcName == "regexp_instr")
|
||||
if (funcName == "locate" || funcName == "find_in_set" || funcName == "strcmp" ||
|
||||
funcName == "regexp_instr")
|
||||
{
|
||||
DTCollation dt;
|
||||
ifp->Type_std_attributes::agg_arg_charsets_for_comparison(dt, ifp->func_name_cstring(),
|
||||
@ -8086,18 +8096,18 @@ int getSelectPlan(gp_walk_info& gwi, SELECT_LEX& select_lex, SCSEP& csep, bool i
|
||||
ReturnedColumn* rc = buildSimpleColumn(ifp, gwi);
|
||||
SimpleColumn* sc = dynamic_cast<SimpleColumn*>(rc);
|
||||
|
||||
if (sc)
|
||||
{
|
||||
bool found = false;
|
||||
if (sc)
|
||||
{
|
||||
bool found = false;
|
||||
for (uint32_t j = 0; j < gwi.returnedCols.size(); j++)
|
||||
{
|
||||
if (sc->sameColumn(gwi.returnedCols[j].get()))
|
||||
{
|
||||
sc->orderPos(j);
|
||||
found = true;
|
||||
found = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
for (uint32_t j = 0; !found && j < gwi.returnedCols.size(); j++)
|
||||
{
|
||||
if (strcasecmp(sc->alias().c_str(), gwi.returnedCols[j]->alias().c_str()) == 0)
|
||||
@ -8107,9 +8117,9 @@ int getSelectPlan(gp_walk_info& gwi, SELECT_LEX& select_lex, SCSEP& csep, bool i
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
}
|
||||
else
|
||||
{
|
||||
for (uint32_t j = 0; j < gwi.returnedCols.size(); j++)
|
||||
{
|
||||
if (ifp->name.length && string(ifp->name.str) == gwi.returnedCols[j].get()->alias())
|
||||
@ -8119,7 +8129,7 @@ int getSelectPlan(gp_walk_info& gwi, SELECT_LEX& select_lex, SCSEP& csep, bool i
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!rc)
|
||||
{
|
||||
@ -9841,7 +9851,7 @@ int getGroupPlan(gp_walk_info& gwi, SELECT_LEX& select_lex, SCSEP& csep, cal_gro
|
||||
}
|
||||
}
|
||||
|
||||
srcp->orderPos(groupcol->counter - 1);
|
||||
srcp->orderPos(groupcol->counter - 1);
|
||||
gwi.groupByCols.push_back(srcp);
|
||||
continue;
|
||||
}
|
||||
|
Reference in New Issue
Block a user