]> granicus.if.org Git - postgresql/commitdiff
Repair error with not adjusting active scans properly after gistSplit.
authorTom Lane <tgl@sss.pgh.pa.us>
Tue, 28 May 2002 15:22:33 +0000 (15:22 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Tue, 28 May 2002 15:22:33 +0000 (15:22 +0000)
Patch from Teodor Sigaev.

src/backend/access/gist/gist.c

index 16105696d47790d5419bea7b0f3a1470f44a9853..802690f80fe56b679c8d000dd285d6f72ea5419e 100644 (file)
@@ -8,7 +8,7 @@
  * Portions Copyright (c) 1994, Regents of the University of California
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/access/gist/gist.c,v 1.93 2002/05/24 18:57:55 tgl Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/access/gist/gist.c,v 1.94 2002/05/28 15:22:33 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -494,6 +494,14 @@ gistlayerinsert(Relation r, BlockNumber blkno,
                /* key is modified, so old version must be deleted */
                ItemPointerSet(&oldtid, blkno, child);
                gistdelete(r, &oldtid);
+       
+               /*
+                * if child was splitted, new key for child will be inserted
+                * in the end list of child, so we must say to any scans
+                * that page is changed beginning from 'child' offset
+                */
+               if ( ret & SPLITED )
+                       gistadjscans(r, GISTOP_SPLIT, blkno, child);
        }
 
        ret = INSERTED;
@@ -1411,10 +1419,6 @@ gistSplit(Relation r,
                ItemPointerSet(&(newtup[nlen - 1]->t_tid), lbknum, 1);
        }
 
-
-       /* adjust active scans */
-       gistadjscans(r, GISTOP_SPLIT, BufferGetBlockNumber(buffer), FirstOffsetNumber);
-
        /* !!! pfree */
        pfree(rvectup);
        pfree(lvectup);