diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2000-03-21 05:12:12 +0000 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2000-03-21 05:12:12 +0000 |
commit | 3ee8f7e207b3459372e13603023a9d84bb800e0b (patch) | |
tree | 74c0afa6e70d62f8df75b90900c19645356f3895 /src/interfaces/python/tutorial/func.py | |
parent | aafe86d9959f1c5adfc1d0c6f8ab54609017f182 (diff) | |
download | postgresql-3ee8f7e207b3459372e13603023a9d84bb800e0b.tar.gz postgresql-3ee8f7e207b3459372e13603023a9d84bb800e0b.zip |
Restructure planning code so that preprocessing of targetlist and quals
to simplify constant expressions and expand SubLink nodes into SubPlans
is done in a separate routine subquery_planner() that calls union_planner().
We formerly did most of this work in query_planner(), but that's the
wrong place because it may never see the real targetlist. Splitting
union_planner into two routines also allows us to avoid redundant work
when union_planner is invoked recursively for UNION and inheritance
cases. Upshot is that it is now possible to do something like
select float8(count(*)) / (select count(*) from int4_tbl) from int4_tbl
group by f1;
which has never worked before.
Diffstat (limited to 'src/interfaces/python/tutorial/func.py')
0 files changed, 0 insertions, 0 deletions