Avoid losing track of data for shared tables in pgstats. Report by Michael
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Thu, 7 Jun 2007 19:07:13 +0000 (19:07 +0000)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Thu, 7 Jun 2007 19:07:13 +0000 (19:07 +0000)
Fuhr, patch from Tom Lane after a messier suggestion by me.

src/backend/postmaster/pgstat.c

index 2dc6b282e8816ef92473b76862cf860d3f18cb4d..8fcd619b95176b124101b8a467953ba6c652490e 100644 (file)
@@ -813,7 +813,9 @@ pgstat_vacuum_tabstat(void)
 
                CHECK_FOR_INTERRUPTS();
 
-               if (hash_search(htab, (void *) &dbid, HASH_FIND, NULL) == NULL)
+               /* the DB entry for shared tables (with InvalidOid) is never dropped */
+               if (OidIsValid(dbid) &&
+                       hash_search(htab, (void *) &dbid, HASH_FIND, NULL) == NULL)
                        pgstat_drop_database(dbid);
        }