-
- Downloads
Avoid leaking memory while evaluating arguments for a table function.
ExecMakeTableFunctionResult evaluated the arguments for a function-in-FROM in the query-lifespan memory context. This is insignificant in simple cases where the function relation is scanned only once; but if the function is in a sub-SELECT or is on the inside of a nested loop, any memory consumed during argument evaluation can add up quickly. (The potential for trouble here had been foreseen long ago, per existing comments; but we'd not previously seen a complaint from the field about it.) To fix, create an additional temporary context just for this purpose. Per an example from MauMau. Back-patch to all active branches.
Showing
- src/backend/executor/execQual.c 11 additions, 4 deletionssrc/backend/executor/execQual.c
- src/backend/executor/nodeFunctionscan.c 15 additions, 0 deletionssrc/backend/executor/nodeFunctionscan.c
- src/include/executor/executor.h 1 addition, 0 deletionssrc/include/executor/executor.h
- src/include/nodes/execnodes.h 2 additions, 0 deletionssrc/include/nodes/execnodes.h
Loading
Please register or sign in to comment