pg_am.h
来自「PostgreSQL 8.2中增加了很多企业用户所需要的功能和性能上的提高,其开」· C头文件 代码 · 共 125 行
H
125 行
/*------------------------------------------------------------------------- * * pg_am.h * definition of the system "access method" relation (pg_am) * along with the relation's initial contents. * * * Portions Copyright (c) 1996-2006, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $PostgreSQL: pgsql/src/include/catalog/pg_am.h,v 1.46 2006/07/31 20:09:05 tgl Exp $ * * NOTES * the genbki.sh script reads this file and generates .bki * information from the DATA() statements. * * XXX do NOT break up DATA() statements into multiple lines! * the scripts are not as smart as you might think... * *------------------------------------------------------------------------- */#ifndef PG_AM_H#define PG_AM_H/* ---------------- * postgres.h contains the system type definitions and the * CATALOG(), BKI_BOOTSTRAP and DATA() sugar words so this file * can be read by both genbki.sh and the C compiler. * ---------------- *//* ---------------- * pg_am definition. cpp turns this into * typedef struct FormData_pg_am * ---------------- */#define AccessMethodRelationId 2601CATALOG(pg_am,2601){ NameData amname; /* access method name */ int2 amstrategies; /* total NUMBER of strategies (operators) by * which we can traverse/search this AM */ int2 amsupport; /* total NUMBER of support functions that this * AM uses */ int2 amorderstrategy;/* if this AM has a sort order, the strategy * number of the sort operator. Zero if AM is * not ordered. */ bool amcanunique; /* does AM support UNIQUE indexes? */ bool amcanmulticol; /* does AM support multi-column indexes? */ bool amoptionalkey; /* can query omit key for the first column? */ bool amindexnulls; /* does AM support NULL index entries? */ bool amstorage; /* can storage type differ from column type? */ bool amclusterable; /* does AM support cluster command? */ regproc aminsert; /* "insert this tuple" function */ regproc ambeginscan; /* "start new scan" function */ regproc amgettuple; /* "next valid tuple" function */ regproc amgetmulti; /* "fetch multiple tuples" function */ regproc amrescan; /* "restart this scan" function */ regproc amendscan; /* "end this scan" function */ regproc ammarkpos; /* "mark current scan position" function */ regproc amrestrpos; /* "restore marked scan position" function */ regproc ambuild; /* "build new index" function */ regproc ambulkdelete; /* bulk-delete function */ regproc amvacuumcleanup; /* post-VACUUM cleanup function */ regproc amcostestimate; /* estimate cost of an indexscan */ regproc amoptions; /* parse AM-specific parameters */} FormData_pg_am;/* ---------------- * Form_pg_am corresponds to a pointer to a tuple with * the format of pg_am relation. * ---------------- */typedef FormData_pg_am *Form_pg_am;/* ---------------- * compiler constants for pg_am * ---------------- */#define Natts_pg_am 23#define Anum_pg_am_amname 1#define Anum_pg_am_amstrategies 2#define Anum_pg_am_amsupport 3#define Anum_pg_am_amorderstrategy 4#define Anum_pg_am_amcanunique 5#define Anum_pg_am_amcanmulticol 6#define Anum_pg_am_amoptionalkey 7#define Anum_pg_am_amindexnulls 8#define Anum_pg_am_amstorage 9#define Anum_pg_am_amclusterable 10#define Anum_pg_am_aminsert 11#define Anum_pg_am_ambeginscan 12#define Anum_pg_am_amgettuple 13#define Anum_pg_am_amgetmulti 14#define Anum_pg_am_amrescan 15#define Anum_pg_am_amendscan 16#define Anum_pg_am_ammarkpos 17#define Anum_pg_am_amrestrpos 18#define Anum_pg_am_ambuild 19#define Anum_pg_am_ambulkdelete 20#define Anum_pg_am_amvacuumcleanup 21#define Anum_pg_am_amcostestimate 22#define Anum_pg_am_amoptions 23/* ---------------- * initial contents of pg_am * ---------------- */DATA(insert OID = 403 ( btree 5 1 1 t t t t f t btinsert btbeginscan btgettuple btgetmulti btrescan btendscan btmarkpos btrestrpos btbuild btbulkdelete btvacuumcleanup btcostestimate btoptions ));DESCR("b-tree index access method");#define BTREE_AM_OID 403DATA(insert OID = 405 ( hash 1 1 0 f f f f f f hashinsert hashbeginscan hashgettuple hashgetmulti hashrescan hashendscan hashmarkpos hashrestrpos hashbuild hashbulkdelete hashvacuumcleanup hashcostestimate hashoptions ));DESCR("hash index access method");#define HASH_AM_OID 405DATA(insert OID = 783 ( gist 100 7 0 f t t t t t gistinsert gistbeginscan gistgettuple gistgetmulti gistrescan gistendscan gistmarkpos gistrestrpos gistbuild gistbulkdelete gistvacuumcleanup gistcostestimate gistoptions ));DESCR("GiST index access method");#define GIST_AM_OID 783DATA(insert OID = 2742 ( gin 100 4 0 f f f f t f gininsert ginbeginscan gingettuple gingetmulti ginrescan ginendscan ginmarkpos ginrestrpos ginbuild ginbulkdelete ginvacuumcleanup gincostestimate ginoptions ));DESCR("GIN index access method");#define GIN_AM_OID 2742#endif /* PG_AM_H */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?