Dependency Checking
===================
* Flush cached query plans when the dependent objects change,
when the cardinality of parameters changes dramatically, or
when new ANALYZE statistics are available
A more complex solution would be to save multiple plans for different
cardinality and use the appropriate plan based on the EXECUTE values.
* Track dependencies in function bodies and recompile/invalidate
This is particularly important for references to temporary tables
in PL/PgSQL because PL/PgSQL caches query plans. The only workaround
in PL/PgSQL is to use EXECUTE. One complexity is that a function
might itself drop and recreate dependent tables, causing it to
invalidate its own query plan.
Which of these are done or not done?
--
Bruce Momjian <br...@momjian.us> http://momjian.us
EnterpriseDB http://www.enterprisedb.com
+ If your life is a hard drive, Christ can be your backup. +
---------------------------(end of broadcast)---------------------------
TIP 5: don't forget to increase your free space map settings
Also, is this done:
* Invalidate prepared queries, like INSERT, when the table definition
is altered
--
Bruce Momjian <br...@momjian.us> http://momjian.us
EnterpriseDB http://www.enterprisedb.com
+ If your life is a hard drive, Christ can be your backup. +
---------------------------(end of broadcast)---------------------------
TIP 9: In versions below 8.0, the planner will ignore your desire to
choose an index scan if your joining column's datatypes do not
match
This is partially done --- you'll have to split it into multiple items
if you want to preserve the bit about keeping different plans for
different parameter values. Note that in the current code, any VACUUM
or ANALYZE on a table will force relcache inval and hence replan; see
vac_update_relstats. So the only case not covered as far as
non-parameterized queries go is large growth of a table without any
vacuuming or analyzing ... and you're going to have problems anyway
if you don't analyze after loading a table. We may in fact find that
our problem is now too many replans rather than too few.
>> * Track dependencies in function bodies and recompile/invalidate
>>
>> This is particularly important for references to temporary tables
>> in PL/PgSQL because PL/PgSQL caches query plans.
This is done.
> Also, is this done:
> * Invalidate prepared queries, like INSERT, when the table definition
> is altered
This too.
regards, tom lane
---------------------------(end of broadcast)---------------------------
TIP 6: explain analyze is your friend
* -Flush cached query plans when the dependent objects change or
when new ANALYZE statistics are available
* -Track dependencies in function bodies and recompile/invalidate
* -Invalidate prepared queries, like INSERT, when the table definition
is altered
Let's see if the cardinality issue is still needed after this release.
---------------------------------------------------------------------------
--
Bruce Momjian <br...@momjian.us> http://momjian.us
EnterpriseDB http://www.enterprisedb.com
+ If your life is a hard drive, Christ can be your backup. +
---------------------------(end of broadcast)---------------------------
TIP 7: You can help support the PostgreSQL project by donating at