mirror of
https://github.com/postgres/postgres.git
synced 2025-06-29 10:41:53 +03:00
Delete empty pages during GiST VACUUM.
To do this, we scan GiST two times. In the first pass we make note of empty leaf pages and internal pages. At second pass we scan through internal pages, looking for downlinks to the empty pages. Deleting internal pages is still not supported, like in nbtree, the last child of an internal page is never deleted. That means that if you have a workload where new keys are always inserted to different area than where old keys are removed, the index will still grow without bound. But the rate of growth will be an order of magnitude slower than before. Author: Andrey Borodin Discussion: https://www.postgresql.org/message-id/B1E4DF12-6CD3-4706-BDBD-BF3283328F60@yandex-team.ru
This commit is contained in:
@ -151,6 +151,10 @@ typedef struct GISTENTRY
|
||||
#define GistPageGetNSN(page) ( PageXLogRecPtrGet(GistPageGetOpaque(page)->nsn))
|
||||
#define GistPageSetNSN(page, val) ( PageXLogRecPtrSet(GistPageGetOpaque(page)->nsn, val))
|
||||
|
||||
/* For deleted pages we store last xid which could see the page in scan */
|
||||
#define GistPageGetDeleteXid(page) ( ((PageHeader) (page))->pd_prune_xid )
|
||||
#define GistPageSetDeleteXid(page, val) ( ((PageHeader) (page))->pd_prune_xid = val)
|
||||
|
||||
/*
|
||||
* Vector of GISTENTRY structs; user-defined methods union and picksplit
|
||||
* take it as one of their arguments
|
||||
|
Reference in New Issue
Block a user