From 13ff51baf282ee4bd49036c82625a36007e0f233 Mon Sep 17 00:00:00 2001 From: Teodor Sigaev Date: Tue, 30 Aug 2005 07:57:48 +0000 Subject: Fix missing rows in query update a=.. where a... with GiST index on column 'a' --- src/backend/access/gist/gist.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'src/backend/access/gist/gist.c') diff --git a/src/backend/access/gist/gist.c b/src/backend/access/gist/gist.c index 4ff257338f9..75e29473263 100644 --- a/src/backend/access/gist/gist.c +++ b/src/backend/access/gist/gist.c @@ -8,7 +8,7 @@ * Portions Copyright (c) 1994, Regents of the University of California * * IDENTIFICATION - * $PostgreSQL: pgsql/src/backend/access/gist/gist.c,v 1.112 2004/12/31 21:59:10 pgsql Exp $ + * $PostgreSQL: pgsql/src/backend/access/gist/gist.c,v 1.112.4.1 2005/08/30 07:57:48 teodor Exp $ * *------------------------------------------------------------------------- */ @@ -503,7 +503,7 @@ gistlayerinsert(Relation r, BlockNumber blkno, * changed beginning from 'child' offset */ if (ret & SPLITED) - gistadjscans(r, GISTOP_SPLIT, blkno, child); + gistadjscans(r, GISTOP_SPLIT, nblkno, FirstOffsetNumber); } ret = INSERTED; @@ -1420,6 +1420,9 @@ gistnewroot(Relation r, IndexTuple *itup, int len) Page p; b = ReadBuffer(r, GISTP_ROOT); + + gistadjscans(r, GISTOP_SPLIT, GISTP_ROOT, FirstOffsetNumber); + GISTInitBuffer(b, 0); p = BufferGetPage(b); -- cgit v1.2.3