You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-07-30 19:23:07 +03:00
MCOL-2178 Fix for handlers fallback mechanism patch.
I returned if predicate that guards FE-BE initial connection
block. This predicated had been removed by accident in cb36041
Since we switched to internal ORDER BY FE now reduces the
default limit value to uint64-2 this broke a predicate check
for correlated subqueries. I replaced a predicate with more
reasonable to avoid false positives.
This commit is contained in:
@ -7865,8 +7865,7 @@ int getSelectPlan(gp_walk_info& gwi, SELECT_LEX& select_lex,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// We don't currently support limit with correlated subquery
|
// We don't currently support limit with correlated subquery
|
||||||
if (csep->limitNum() != (uint64_t) - 1 &&
|
if (gwi.subQuery && !gwi.correlatedTbNameVec.empty() && csep->hasOrderBy())
|
||||||
gwi.subQuery && !gwi.correlatedTbNameVec.empty())
|
|
||||||
{
|
{
|
||||||
gwi.fatalParseError = true;
|
gwi.fatalParseError = true;
|
||||||
gwi.parseErrorText = IDBErrorInfo::instance()->errorMsg(ERR_NON_SUPPORT_LIMIT_SUB);
|
gwi.parseErrorText = IDBErrorInfo::instance()->errorMsg(ERR_NON_SUPPORT_LIMIT_SUB);
|
||||||
|
@ -5319,52 +5319,55 @@ int ha_cs_impl_select_next(uchar* buf, TABLE* table)
|
|||||||
sm::tableid_t tableid= execplan::IDB_VTABLE_ID;
|
sm::tableid_t tableid= execplan::IDB_VTABLE_ID;
|
||||||
sm::cpsm_conhdl_t* hndl= ci->cal_conn_hndl;
|
sm::cpsm_conhdl_t* hndl= ci->cal_conn_hndl;
|
||||||
|
|
||||||
if (ti.tpl_ctx == 0)
|
if (!ti.tpl_ctx || !ti.tpl_scan_ctx || (hndl && hndl->queryState == sm::NO_QUERY))
|
||||||
{
|
{
|
||||||
ti.tpl_ctx = new sm::cpsm_tplh_t();
|
if (ti.tpl_ctx == 0)
|
||||||
ti.tpl_scan_ctx = sm::sp_cpsm_tplsch_t(new sm::cpsm_tplsch_t());
|
|
||||||
}
|
|
||||||
|
|
||||||
// make sure rowgroup is null so the new meta data can be taken. This is for some case mysql
|
|
||||||
// call rnd_init for a table more than once.
|
|
||||||
ti.tpl_scan_ctx->rowGroup = NULL;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
sm::tpl_open(tableid, ti.tpl_ctx, hndl);
|
|
||||||
sm::tpl_scan_open(tableid, ti.tpl_scan_ctx, hndl);
|
|
||||||
}
|
|
||||||
catch (std::exception& e)
|
|
||||||
{
|
|
||||||
uint32_t sessionID = tid2sid(thd->thread_id);
|
|
||||||
string emsg = "table can not be opened: " + string(e.what());
|
|
||||||
setError(thd, ER_INTERNAL_ERROR, emsg);
|
|
||||||
CalpontSystemCatalog::removeCalpontSystemCatalog(sessionID);
|
|
||||||
goto internal_error;
|
|
||||||
}
|
|
||||||
catch (...)
|
|
||||||
{
|
|
||||||
uint32_t sessionID = tid2sid(thd->thread_id);
|
|
||||||
string emsg = "table can not be opened";
|
|
||||||
setError(thd, ER_INTERNAL_ERROR, emsg);
|
|
||||||
CalpontSystemCatalog::removeCalpontSystemCatalog(sessionID);
|
|
||||||
goto internal_error;
|
|
||||||
}
|
|
||||||
|
|
||||||
ti.tpl_scan_ctx->traceFlags = ci->traceFlags;
|
|
||||||
|
|
||||||
if ((ti.tpl_scan_ctx->ctp).size() == 0)
|
|
||||||
{
|
|
||||||
uint32_t num_attr = table->s->fields;
|
|
||||||
|
|
||||||
for (uint32_t i = 0; i < num_attr; i++)
|
|
||||||
{
|
{
|
||||||
CalpontSystemCatalog::ColType ctype;
|
ti.tpl_ctx = new sm::cpsm_tplh_t();
|
||||||
ti.tpl_scan_ctx->ctp.push_back(ctype);
|
ti.tpl_scan_ctx = sm::sp_cpsm_tplsch_t(new sm::cpsm_tplsch_t());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// make sure rowgroup is null so the new meta data can be taken. This is for some case mysql
|
||||||
|
// call rnd_init for a table more than once.
|
||||||
|
ti.tpl_scan_ctx->rowGroup = NULL;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
sm::tpl_open(tableid, ti.tpl_ctx, hndl);
|
||||||
|
sm::tpl_scan_open(tableid, ti.tpl_scan_ctx, hndl);
|
||||||
|
}
|
||||||
|
catch (std::exception& e)
|
||||||
|
{
|
||||||
|
uint32_t sessionID = tid2sid(thd->thread_id);
|
||||||
|
string emsg = "table can not be opened: " + string(e.what());
|
||||||
|
setError(thd, ER_INTERNAL_ERROR, emsg);
|
||||||
|
CalpontSystemCatalog::removeCalpontSystemCatalog(sessionID);
|
||||||
|
goto internal_error;
|
||||||
|
}
|
||||||
|
catch (...)
|
||||||
|
{
|
||||||
|
uint32_t sessionID = tid2sid(thd->thread_id);
|
||||||
|
string emsg = "table can not be opened";
|
||||||
|
setError(thd, ER_INTERNAL_ERROR, emsg);
|
||||||
|
CalpontSystemCatalog::removeCalpontSystemCatalog(sessionID);
|
||||||
|
goto internal_error;
|
||||||
|
}
|
||||||
|
|
||||||
|
ti.tpl_scan_ctx->traceFlags = ci->traceFlags;
|
||||||
|
|
||||||
|
if ((ti.tpl_scan_ctx->ctp).size() == 0)
|
||||||
|
{
|
||||||
|
uint32_t num_attr = table->s->fields;
|
||||||
|
|
||||||
|
for (uint32_t i = 0; i < num_attr; i++)
|
||||||
|
{
|
||||||
|
CalpontSystemCatalog::ColType ctype;
|
||||||
|
ti.tpl_scan_ctx->ctp.push_back(ctype);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ci->tableMap[table] = ti;
|
||||||
|
hndl->queryState= sm::QUERY_IN_PROCESS;
|
||||||
}
|
}
|
||||||
ci->tableMap[table] = ti;
|
|
||||||
hndl->queryState= sm::QUERY_IN_PROCESS;
|
|
||||||
|
|
||||||
if (!ti.tpl_ctx || !ti.tpl_scan_ctx)
|
if (!ti.tpl_ctx || !ti.tpl_scan_ctx)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user