mirror of
https://github.com/postgres/postgres.git
synced 2025-08-19 23:22:23 +03:00
Evaluate arguments of correlated SubPlans in the referencing ExprState
Until now we generated an ExprState for each parameter to a SubPlan and evaluated them one-by-one ExecScanSubPlan. That's sub-optimal as creating lots of small ExprStates a) makes JIT compilation more expensive b) wastes memory c) is a bit slower to execute This commit arranges to evaluate parameters to a SubPlan as part of the ExprState referencing a SubPlan, using the new EEOP_PARAM_SET expression step. We emit one EEOP_PARAM_SET for each argument to a subplan, just before the EEOP_SUBPLAN step. It likely is worth using EEOP_PARAM_SET in other places as well, e.g. for SubPlan outputs, nestloop parameters and - more ambitiously - to get rid of ExprContext->domainValue/caseValue/ecxt_agg*. But that's for later. Author: Andres Freund <andres@anarazel.de> Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Reviewed-by: Alena Rybakina <lena.ribackina@yandex.ru> Discussion: https://postgr.es/m/20230225214401.346ancgjqc3zmvek@awork3.anarazel.de
This commit is contained in:
@@ -450,6 +450,7 @@ ExecInterpExpr(ExprState *state, ExprContext *econtext, bool *isnull)
|
||||
&&CASE_EEOP_PARAM_EXEC,
|
||||
&&CASE_EEOP_PARAM_EXTERN,
|
||||
&&CASE_EEOP_PARAM_CALLBACK,
|
||||
&&CASE_EEOP_PARAM_SET,
|
||||
&&CASE_EEOP_CASE_TESTVAL,
|
||||
&&CASE_EEOP_MAKE_READONLY,
|
||||
&&CASE_EEOP_IOCOERCE,
|
||||
@@ -1093,6 +1094,13 @@ ExecInterpExpr(ExprState *state, ExprContext *econtext, bool *isnull)
|
||||
EEO_NEXT();
|
||||
}
|
||||
|
||||
EEO_CASE(EEOP_PARAM_SET)
|
||||
{
|
||||
/* out of line, unlikely to matter performancewise */
|
||||
ExecEvalParamSet(state, op, econtext);
|
||||
EEO_NEXT();
|
||||
}
|
||||
|
||||
EEO_CASE(EEOP_CASE_TESTVAL)
|
||||
{
|
||||
/*
|
||||
@@ -2555,6 +2563,24 @@ ExecEvalParamExtern(ExprState *state, ExprEvalStep *op, ExprContext *econtext)
|
||||
errmsg("no value found for parameter %d", paramId)));
|
||||
}
|
||||
|
||||
/*
|
||||
* Set value of a param (currently always PARAM_EXEC) from
|
||||
* state->res{value,null}.
|
||||
*/
|
||||
void
|
||||
ExecEvalParamSet(ExprState *state, ExprEvalStep *op, ExprContext *econtext)
|
||||
{
|
||||
ParamExecData *prm;
|
||||
|
||||
prm = &(econtext->ecxt_param_exec_vals[op->d.param.paramid]);
|
||||
|
||||
/* Shouldn't have a pending evaluation anymore */
|
||||
Assert(prm->execPlan == NULL);
|
||||
|
||||
prm->value = state->resvalue;
|
||||
prm->isnull = state->resnull;
|
||||
}
|
||||
|
||||
/*
|
||||
* Evaluate a CoerceViaIO node in soft-error mode.
|
||||
*
|
||||
|
Reference in New Issue
Block a user