postgresql/src/include/catalog/index.h

73 lines
1.8 KiB
C
Raw Normal View History

/*-------------------------------------------------------------------------
*
* index.h
* prototypes for catalog/index.c.
*
*
* Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
* $PostgreSQL: pgsql/src/include/catalog/index.h,v 1.69 2006/07/13 16:49:19 momjian Exp $
*
*-------------------------------------------------------------------------
*/
#ifndef INDEX_H
#define INDEX_H
1999-07-16 19:07:40 +02:00
#include "nodes/execnodes.h"
#define DEFAULT_INDEX_TYPE "btree"
/* Typedef for callback function for IndexBuildHeapScan */
typedef void (*IndexBuildCallback) (Relation index,
2005-10-15 04:49:52 +02:00
HeapTuple htup,
Datum *values,
bool *isnull,
bool tupleIsAlive,
void *state);
extern Oid index_create(Oid heapRelationId,
const char *indexRelationName,
Oid indexRelationId,
2001-03-22 05:01:46 +01:00
IndexInfo *indexInfo,
Oid accessMethodObjectId,
Oid tableSpaceId,
2001-03-22 05:01:46 +01:00
Oid *classObjectId,
Datum reloptions,
bool isprimary,
bool istoast,
bool isconstraint,
bool allow_system_table_mods,
bool skip_build);
extern void index_drop(Oid indexId);
extern IndexInfo *BuildIndexInfo(Relation index);
extern void FormIndexDatum(IndexInfo *indexInfo,
TupleTableSlot *slot,
EState *estate,
Datum *values,
bool *isnull);
2000-12-08 07:17:58 +01:00
extern void setNewRelfilenode(Relation relation);
2001-03-22 05:01:46 +01:00
extern void index_build(Relation heapRelation,
Relation indexRelation,
IndexInfo *indexInfo,
bool isprimary,
bool istoast);
extern double IndexBuildHeapScan(Relation heapRelation,
Relation indexRelation,
IndexInfo *indexInfo,
IndexBuildCallback callback,
void *callback_state);
extern void reindex_index(Oid indexId);
extern bool reindex_relation(Oid relid, bool toast_too);
#endif /* INDEX_H */