mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	First cut at recycling space in btree indexes. Still some rough edges
to fix, but it seems to basically work...
This commit is contained in:
		| @@ -7,7 +7,7 @@ | ||||
|  * Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group | ||||
|  * Portions Copyright (c) 1994, Regents of the University of California | ||||
|  * | ||||
|  * $Id: itup.h,v 1.36 2002/08/25 17:20:01 tgl Exp $ | ||||
|  * $Id: itup.h,v 1.37 2003/02/23 06:17:13 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -133,11 +133,11 @@ typedef InsertIndexResultData *InsertIndexResult; | ||||
| ) | ||||
|  | ||||
|  | ||||
| /* indextuple.h */ | ||||
| /* routines in indextuple.c */ | ||||
| extern IndexTuple index_formtuple(TupleDesc tupleDescriptor, | ||||
| 				Datum *value, char *null); | ||||
| extern Datum nocache_index_getattr(IndexTuple tup, int attnum, | ||||
| 					  TupleDesc tupleDesc, bool *isnull); | ||||
| extern void CopyIndexTuple(IndexTuple source, IndexTuple *target); | ||||
| extern IndexTuple CopyIndexTuple(IndexTuple source); | ||||
|  | ||||
| #endif   /* ITUP_H */ | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  * Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group | ||||
|  * Portions Copyright (c) 1994, Regents of the University of California | ||||
|  * | ||||
|  * $Id: nbtree.h,v 1.65 2003/02/22 00:45:05 tgl Exp $ | ||||
|  * $Id: nbtree.h,v 1.66 2003/02/23 06:17:13 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -118,6 +118,8 @@ typedef struct BTItemData | ||||
|  | ||||
| typedef BTItemData *BTItem; | ||||
|  | ||||
| #define CopyBTItem(btitem) ((BTItem) CopyIndexTuple((IndexTuple) (btitem))) | ||||
|  | ||||
| /* | ||||
|  * For XLOG: size without alignment. Sizeof works as long as | ||||
|  * IndexTupleData has exactly 8 bytes. | ||||
| @@ -434,6 +436,7 @@ extern Datum btvacuumcleanup(PG_FUNCTION_ARGS); | ||||
|  */ | ||||
| extern InsertIndexResult _bt_doinsert(Relation rel, BTItem btitem, | ||||
| 			 bool index_is_unique, Relation heapRel); | ||||
| extern Buffer _bt_getstackbuf(Relation rel, BTStack stack, int access); | ||||
| extern void _bt_insert_parent(Relation rel, Buffer buf, Buffer rbuf, | ||||
| 							  BTStack stack, bool is_root, bool is_only); | ||||
|  | ||||
| @@ -448,8 +451,10 @@ extern void _bt_relbuf(Relation rel, Buffer buf); | ||||
| extern void _bt_wrtbuf(Relation rel, Buffer buf); | ||||
| extern void _bt_wrtnorelbuf(Relation rel, Buffer buf); | ||||
| extern void _bt_pageinit(Page page, Size size); | ||||
| extern bool _bt_page_recyclable(Page page); | ||||
| extern void _bt_metaproot(Relation rel, BlockNumber rootbknum, uint32 level); | ||||
| extern void _bt_itemdel(Relation rel, Buffer buf, ItemPointer tid); | ||||
| extern int	_bt_pagedel(Relation rel, Buffer buf, bool vacuum_full); | ||||
|  | ||||
| /* | ||||
|  * prototypes for functions in nbtsearch.c | ||||
| @@ -488,7 +493,6 @@ extern BTItem _bt_formitem(IndexTuple itup); | ||||
| /* | ||||
|  * prototypes for functions in nbtsort.c | ||||
|  */ | ||||
|  | ||||
| typedef struct BTSpool BTSpool; /* opaque type known only within nbtsort.c */ | ||||
|  | ||||
| extern BTSpool *_bt_spoolinit(Relation index, bool isunique); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user