mirror of
https://github.com/postgres/postgres.git
synced 2025-06-11 00:02:09 -04:00
Add missing MaterialPath support in reparameterize_path[_by_child].
These two functions failed to cover MaterialPath. That's not a fatal problem, but we can generate better plans in some cases if we support it. Tom Lane and Richard Guo Discussion: https://postgr.es/m/1854233.1669949723@sss.pgh.pa.us
This commit is contained in:
parent
fe12f2f8fa
commit
6eb2f0ed4c
@ -3979,6 +3979,18 @@ reparameterize_path(PlannerInfo *root, Path *path,
|
|||||||
apath->path.parallel_aware,
|
apath->path.parallel_aware,
|
||||||
-1);
|
-1);
|
||||||
}
|
}
|
||||||
|
case T_Material:
|
||||||
|
{
|
||||||
|
MaterialPath *mpath = (MaterialPath *) path;
|
||||||
|
Path *spath = mpath->subpath;
|
||||||
|
|
||||||
|
spath = reparameterize_path(root, spath,
|
||||||
|
required_outer,
|
||||||
|
loop_count);
|
||||||
|
if (spath == NULL)
|
||||||
|
return NULL;
|
||||||
|
return (Path *) create_material_path(rel, spath);
|
||||||
|
}
|
||||||
case T_Memoize:
|
case T_Memoize:
|
||||||
{
|
{
|
||||||
MemoizePath *mpath = (MemoizePath *) path;
|
MemoizePath *mpath = (MemoizePath *) path;
|
||||||
@ -4013,7 +4025,8 @@ reparameterize_path(PlannerInfo *root, Path *path,
|
|||||||
* path->parent, which does not change during the translation. Hence those
|
* path->parent, which does not change during the translation. Hence those
|
||||||
* members are copied as they are.
|
* members are copied as they are.
|
||||||
*
|
*
|
||||||
* If the given path can not be reparameterized, the function returns NULL.
|
* Currently, only a few path types are supported here, though more could be
|
||||||
|
* added at need. We return NULL if we can't reparameterize the given path.
|
||||||
*/
|
*/
|
||||||
Path *
|
Path *
|
||||||
reparameterize_path_by_child(PlannerInfo *root, Path *path,
|
reparameterize_path_by_child(PlannerInfo *root, Path *path,
|
||||||
@ -4211,6 +4224,16 @@ do { \
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case T_MaterialPath:
|
||||||
|
{
|
||||||
|
MaterialPath *mpath;
|
||||||
|
|
||||||
|
FLAT_COPY_PATH(mpath, path, MaterialPath);
|
||||||
|
REPARAMETERIZE_CHILD_PATH(mpath->subpath);
|
||||||
|
new_path = (Path *) mpath;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case T_MemoizePath:
|
case T_MemoizePath:
|
||||||
{
|
{
|
||||||
MemoizePath *mpath;
|
MemoizePath *mpath;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user