• Tom Lane's avatar
    Restructure index AM interface for index building and index tuple deletion, · c8076f09
    Tom Lane authored
    per previous discussion on pghackers.  Most of the duplicate code in
    different AMs' ambuild routines has been moved out to a common routine
    in index.c; this means that all index types now do the right things about
    inserting recently-dead tuples, etc.  (I also removed support for EXTEND
    INDEX in the ambuild routines, since that's about to go away anyway, and
    it cluttered the code a lot.)  The retail indextuple deletion routines have
    been replaced by a "bulk delete" routine in which the indexscan is inside
    the access method.  I haven't pushed this change as far as it should go yet,
    but it should allow considerable simplification of the internal bookkeeping
    for deletions.  Also, add flag columns to pg_am to eliminate various
    hardcoded tests on AM OIDs, and remove unused pg_am columns.
    
    Fix rtree and gist index types to not attempt to store NULLs; before this,
    gist usually crashed, while rtree managed not to crash but computed wacko
    bounding boxes for NULL entries (which might have had something to do with
    the performance problems we've heard about occasionally).
    
    Add AtEOXact routines to hash, rtree, and gist, all of which have static
    state that needs to be reset after an error.  We discovered this need long
    ago for btree, but missed the other guys.
    
    Oh, one more thing: concurrent VACUUM is now the default.
    c8076f09
oidjoins.out 11.1 KB