]> granicus.if.org Git - postgresql/commit
I checked the alter table code, and started suspecting the relation
authorBruce Momjian <bruce@momjian.us>
Sun, 13 Oct 1996 04:26:39 +0000 (04:26 +0000)
committerBruce Momjian <bruce@momjian.us>
Sun, 13 Oct 1996 04:26:39 +0000 (04:26 +0000)
commitabb1b3e770fd09acc44bc2152d10020d9479f600
treed6a93daaa76be70b27f0bf3f691e24ff7c710933
parentbef3c89a1cea3f9d6ab749fd7636952a980de35a
I checked the alter table code, and started suspecting the relation
cache.  I found if I manually added a line to flush the whole relation
cache, the assert error disappeared.  Looking through the code, I found
that the relation cache is flushed at the end of each query if the
reference count is zero for the relation.  However, printf's showed that
the rd_relcnt(reference count) for the accessed query was not returning
to zero after each query.

It turns out the parser was doing a heap_ropen in parser/analyze.c to
get information about the table's columns, but was not doing a
heap_close.

This was causing the query after the ALTER TABLE ADD to see the old
table structure, and the executor's assert was reporting the problem.
src/Makefile.global
src/backend/parser/analyze.c
src/include/parser/parse_state.h