mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-06 15:24:56 +08:00
447 lines
16 KiB
Groff
447 lines
16 KiB
Groff
|
.\" This is -*-nroff-*-
|
||
|
.\" XXX standard disclaimer belongs here....
|
||
|
.\" $Header: /cvsroot/pgsql/doc/man/Attic/catalogs.3,v 1.1.1.1 1996/08/18 22:14:20 scrappy Exp $
|
||
|
.TH "SYSTEM CATALOGS" INTRO 03/13/94 Postgres95 Postgres95
|
||
|
.SH "Section 7 \(em System Catalogs"
|
||
|
.de LS
|
||
|
.PP
|
||
|
.if n .ta 5 +13 +13
|
||
|
.if t .ta 0.5i +1.3i +1.3i
|
||
|
.in 0
|
||
|
.nf
|
||
|
..
|
||
|
.de LE
|
||
|
.fi
|
||
|
.in
|
||
|
..
|
||
|
.SH "DESCRIPTION"
|
||
|
In this
|
||
|
section we list each of the attributes of the system catalogs and
|
||
|
define their meanings.
|
||
|
.SH "CLASS/TYPE SYSTEM CATALOGS"
|
||
|
These catalogs form the core of the extensibility system:
|
||
|
.LS
|
||
|
\fBname\fP \fBshared/local\fP \fBdescription\fP
|
||
|
pg_aggregate local aggregate functions
|
||
|
pg_am local access methods
|
||
|
pg_amop local operators usable with specific access methods
|
||
|
pg_amproc local procedures used with specific access methods
|
||
|
pg_attribute local class attributes
|
||
|
pg_class local classes
|
||
|
pg_index local secondary indices
|
||
|
pg_inherits local class inheritance hierarchy
|
||
|
pg_language local procedure implementation languages
|
||
|
pg_opclass local operator classes
|
||
|
pg_operator local query language operators
|
||
|
pg_proc local procedures (functions)
|
||
|
pg_type local data types
|
||
|
.LE
|
||
|
.SH "ENTITIES"
|
||
|
These catalogs deal with identification of entities known throughout
|
||
|
the site:
|
||
|
.LS
|
||
|
\fBname\fP \fBshared/local\fP \fBdescription\fP
|
||
|
pg_database shared current databases
|
||
|
pg_group shared user groups
|
||
|
pg_user shared valid users
|
||
|
.LE
|
||
|
.SH "RULE SYSTEM CATALOGS"
|
||
|
.LS
|
||
|
\fBname\fP \fBshared/local\fP \fBdescription\fP
|
||
|
pg_listener local processes waiting on alerters
|
||
|
pg_prs2plans local instance system procedures
|
||
|
pg_prs2rule local instance system rules
|
||
|
pg_prs2stub local instance system ``stubs''
|
||
|
pg_rewrite local rewrite system information
|
||
|
.LE
|
||
|
.SH "LARGE OBJECT CATALOGS"
|
||
|
.PP
|
||
|
These catalogs are specific to the Inversion file system and large
|
||
|
objects in general:
|
||
|
.LS
|
||
|
\fBname\fP \fBshared/local\fP \fBdescription\fP
|
||
|
pg_lobj local description of a large object
|
||
|
pg_naming local Inversion name space mapping
|
||
|
pg_platter local jukebox platter inventory
|
||
|
pg_plmap local jukebox platter extent map
|
||
|
.LE
|
||
|
.SH "INTERNAL CATALOGS"
|
||
|
.PP
|
||
|
These catalogs are internal classes that are not stored as normal
|
||
|
heaps and cannot be accessed through normal means (attempting to do so
|
||
|
causes an error).
|
||
|
.LS
|
||
|
\fBname\fP \fBshared/local\fP \fBdescription\fP
|
||
|
pg_log shared transaction commit/abort log
|
||
|
pg_magic shared magic constant
|
||
|
pg_time shared commit/abort times
|
||
|
pg_variable shared special variable values
|
||
|
.LE
|
||
|
.PP
|
||
|
There are several other classes defined with \*(lqpg_\*(rq names.
|
||
|
Aside from those that end in \*(lqind\*(rq (secondary indices), these
|
||
|
are all obsolete or otherwise deprecated.
|
||
|
.SH "CLASS/TYPE SYSTEM CATALOGS"
|
||
|
.PP
|
||
|
The following catalogs relate to the class/type system.
|
||
|
.nf M
|
||
|
/*
|
||
|
* aggregates
|
||
|
*
|
||
|
* see DEFINE AGGREGATE for an explanation of transition functions
|
||
|
*/
|
||
|
pg_aggregate
|
||
|
NameData aggname /* aggregate name (e.g., "count") */
|
||
|
oid aggowner /* usesysid of creator */
|
||
|
regproc aggtransfn1 /* first transition function */
|
||
|
regproc aggtransfn2 /* second transition function */
|
||
|
regproc aggfinalfn /* final function */
|
||
|
oid aggbasetype /* type of data on which aggregate
|
||
|
operates */
|
||
|
oid aggtranstype1 /* type returned by aggtransfn1 */
|
||
|
oid aggtranstype2 /* type returned by aggtransfn2 */
|
||
|
oid aggfinaltype /* type returned by aggfinalfn */
|
||
|
text agginitval1 /* external format of initial
|
||
|
(starting) value of aggtransfn1 */
|
||
|
text agginitval2 /* external format of initial
|
||
|
(starting) value of aggtransfn2 */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_am
|
||
|
NameData amname /* access method name */
|
||
|
oid amowner /* usesysid of creator */
|
||
|
char amkind /* - deprecated */
|
||
|
/* originally:
|
||
|
h=hashed
|
||
|
o=ordered
|
||
|
s=special */
|
||
|
int2 amstrategies /* total NUMBER of strategies by which
|
||
|
we can traverse/search this AM */
|
||
|
int2 amsupport /* total NUMBER of support functions
|
||
|
that this AM uses */
|
||
|
regproc amgettuple /* "next valid tuple" function */
|
||
|
regproc aminsert /* "insert this tuple" function */
|
||
|
regproc amdelete /* "delete this tuple" function */
|
||
|
regproc amgetattr /* - deprecated */
|
||
|
regproc amsetlock /* - deprecated */
|
||
|
regproc amsettid /* - deprecated */
|
||
|
regproc amfreetuple /* - deprecated */
|
||
|
regproc ambeginscan /* "start new scan" 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 amopen /* - deprecated */
|
||
|
regproc amclose /* - deprecated */
|
||
|
regproc ambuild /* "build new index" function */
|
||
|
regproc amcreate /* - deprecated */
|
||
|
regproc amdestroy /* - deprecated */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_amop
|
||
|
oid amopid /* access method with which this
|
||
|
operator be used */
|
||
|
oid amopclaid /* operator class with which this
|
||
|
operator can be used */
|
||
|
oid amopopr /* the operator */
|
||
|
int2 amopstrategy /* traversal/search strategy number
|
||
|
to which this operator applies */
|
||
|
regproc amopselect /* function to calculate the operator
|
||
|
selectivity */
|
||
|
regproc amopnpages /* function to calculate the number of
|
||
|
pages that will be examined */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_amproc
|
||
|
oid amid /* access method with which this
|
||
|
procedure is associated */
|
||
|
oid amopclaid /* operator class with which this
|
||
|
operator can be used */
|
||
|
oid amproc /* the procedure */
|
||
|
int2 amprocnum /* support function number to which
|
||
|
this operator applies */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_class
|
||
|
NameData relname /* class name */
|
||
|
oid relowner /* usesysid of owner */
|
||
|
oid relam /* access method */
|
||
|
int4 relpages /* # of 8KB pages */
|
||
|
int4 reltuples /* # of instances */
|
||
|
abstime relexpires /* time after which instances are
|
||
|
deleted from non-archival storage */
|
||
|
reltime relpreserved /* timespan after which instances are
|
||
|
deleted from non-archival storage */
|
||
|
bool relhasindex /* does the class have a secondary
|
||
|
index? */
|
||
|
bool relisshared /* is the class shared or local? */
|
||
|
char relkind /* type of relation:
|
||
|
i=index
|
||
|
r=relation (heap)
|
||
|
s=special
|
||
|
u=uncatalogued (temporary) */
|
||
|
char relarch /* archive mode:
|
||
|
h=heavy
|
||
|
l=light
|
||
|
n=none */
|
||
|
int2 relnatts /* current # of non-system
|
||
|
attributes */
|
||
|
int2 relsmgr /* storage manager:
|
||
|
0=magnetic disk
|
||
|
1=sony WORM jukebox
|
||
|
2=main memory */
|
||
|
int28 relkey /* - unused */
|
||
|
oid8 relkeyop /* - unused */
|
||
|
aclitem relacl[1] /* access control lists */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_attribute
|
||
|
oid attrelid /* class containing this attribute */
|
||
|
NameData attname /* attribute name */
|
||
|
oid atttypid /* attribute type */
|
||
|
oid attdefrel /* - deprecated */
|
||
|
int4 attnvals /* - deprecated */
|
||
|
oid atttyparg /* - deprecated */
|
||
|
int2 attlen /* attribute length, in bytes
|
||
|
-1=variable */
|
||
|
int2 attnum /* attribute number
|
||
|
>0=user attribute
|
||
|
<0=system attribute */
|
||
|
int2 attbound /* - deprecated */
|
||
|
bool attbyval /* type passed by value? */
|
||
|
bool attcanindex /* - deprecated */
|
||
|
oid attproc /* - deprecated */
|
||
|
int4 attnelems /* # of array dimensions */
|
||
|
int4 attcacheoff /* cached offset into tuple */
|
||
|
bool attisset /* is attribute set-valued? */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_inherits
|
||
|
oid inhrel /* child class */
|
||
|
oid inhparent /* parent class */
|
||
|
int4 inhseqno /* - deprecated */
|
||
|
.fi
|
||
|
.nf M
|
||
|
oid indexrelid /* oid of secondary index class */
|
||
|
oid indrelid /* oid of indexed heap class */
|
||
|
oid indproc /* function to compute index key from
|
||
|
attribute(s) in heap
|
||
|
0=not a functional index */
|
||
|
int28 indkey /* attribute numbers of key
|
||
|
attribute(s) */
|
||
|
oid8 indclass /* opclass of each key */
|
||
|
bool indisclustered /* is the index clustered?
|
||
|
- unused */
|
||
|
bool indisarchived /* is the index archival?
|
||
|
- unused */
|
||
|
text indpred /* query plan for partial index
|
||
|
predicate */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_type
|
||
|
NameData typname /* type name */
|
||
|
oid typowner /* usesysid of owner */
|
||
|
int2 typlen /* length in internal form
|
||
|
-1=variable-length */
|
||
|
int2 typprtlen /* length in external form */
|
||
|
bool typbyval /* type passed by value? */
|
||
|
char typtype /* kind of type:
|
||
|
c=catalog (composite)
|
||
|
b=base */
|
||
|
bool typisdefined /* defined or still a shell? */
|
||
|
char typdelim /* delimiter for array external form */
|
||
|
oid typrelid /* class (if composite) */
|
||
|
oid typelem /* type of each array element */
|
||
|
regproc typinput /* external-internal conversion
|
||
|
function */
|
||
|
regproc typoutput /* internal-external conversion
|
||
|
function */
|
||
|
regproc typreceive /* client-server conversion function */
|
||
|
regproc typsend /* server-client conversion function */
|
||
|
text typdefault /* default value */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_operator
|
||
|
NameData oprname /* operator name */
|
||
|
oid oprowner /* usesysid of owner */
|
||
|
int2 oprprec /* - deprecated */
|
||
|
char oprkind /* kind of operator:
|
||
|
b=binary
|
||
|
l=left unary
|
||
|
r=right unary */
|
||
|
bool oprisleft /* is operator left/right associative? */
|
||
|
bool oprcanhash /* is operator usable for hashjoin? */
|
||
|
oid oprleft /* left operand type */
|
||
|
oid oprright /* right operand type */
|
||
|
oid oprresult /* result type */
|
||
|
oid oprcom /* commutator operator */
|
||
|
oid oprnegate /* negator operator */
|
||
|
oid oprlsortop /* sort operator for left operand */
|
||
|
oid oprrsortop /* sort operator for right operand */
|
||
|
regproc oprcode /* function implementing this operator */
|
||
|
regproc oprrest /* function to calculate operator
|
||
|
restriction selectivity */
|
||
|
regproc oprjoin /* function to calculate operator
|
||
|
join selectivity */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_opclass
|
||
|
NameData opcname /* operator class name */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_proc
|
||
|
NameData proname /* function name */
|
||
|
oid proowner /* usesysid of owner */
|
||
|
oid prolang /* function implementation language */
|
||
|
bool proisinh /* - deprecated */
|
||
|
bool proistrusted /* run in server or untrusted function
|
||
|
process? */
|
||
|
bool proiscachable /* can the function return values be
|
||
|
cached? */
|
||
|
int2 pronargs /* # of arguments */
|
||
|
bool proretset /* does the function return a set?
|
||
|
- unused */
|
||
|
oid prorettype /* return type */
|
||
|
oid8 proargtypes /* argument types */
|
||
|
int4 probyte_pct /* % of argument size (in bytes) that
|
||
|
needs to be examined in order to
|
||
|
compute the function */
|
||
|
int4 properbyte_cpu /* sensitivity of the function's
|
||
|
running time to the size of its
|
||
|
inputs */
|
||
|
int4 propercall_cpu /* overhead of the function's
|
||
|
invocation (regardless of input
|
||
|
size) */
|
||
|
int4 prooutin_ratio /* size of the function's output as a
|
||
|
percentage of the size of the input */
|
||
|
text prosrc /* function definition (postquel only) */
|
||
|
bytea probin /* path to object file (C only) */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_language
|
||
|
NameData lanname /* language name */
|
||
|
text lancompiler /* - deprecated */
|
||
|
.fi
|
||
|
.SH "ENTITIES"
|
||
|
.nf M
|
||
|
pg_database
|
||
|
NameData datname /* database name */
|
||
|
oid datdba /* usesysid of database administrator */
|
||
|
text datpath /* directory of database under
|
||
|
$PGDATA */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_group
|
||
|
NameData groname /* group name */
|
||
|
int2 grosysid /* group's UNIX group id */
|
||
|
int2 grolist[1] /* list of usesysids of group members */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_user
|
||
|
NameData usename /* user's name */
|
||
|
int2 usesysid /* user's UNIX user id */
|
||
|
bool usecreatedb /* can user create databases? */
|
||
|
bool usetrace /* can user set trace flags? */
|
||
|
bool usesuper /* can user be POSTGRES superuser? */
|
||
|
bool usecatupd /* can user update catalogs? */
|
||
|
.fi
|
||
|
.SH "RULE SYSTEM CATALOGS"
|
||
|
.nf M
|
||
|
pg_listener
|
||
|
NameData relname /* class for which asynchronous
|
||
|
notification is desired */
|
||
|
int4 listenerpid /* process id of server corresponding
|
||
|
to a frontend program waiting for
|
||
|
asynchronous notification */
|
||
|
int4 notification /* whether an event notification for
|
||
|
this process id still pending */
|
||
|
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_prs2rule
|
||
|
NameData prs2name /* rule name */
|
||
|
char prs2eventtype /* rule event type:
|
||
|
R=retrieve
|
||
|
U=update (replace)
|
||
|
A=append
|
||
|
D=delete */
|
||
|
oid prs2eventrel /* class to which event applies */
|
||
|
int2 prs2eventattr /* attribute to which event applies */
|
||
|
float8 necessary /* - deprecated */
|
||
|
float8 sufficient /* - deprecated */
|
||
|
text prs2text /* text of original rule definition */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_prs2plans
|
||
|
oid prs2ruleid /* prs2rule instance for which this
|
||
|
plan is used */
|
||
|
int2 prs2planno /* plan number (one rule may invoke
|
||
|
multiple plans) */
|
||
|
text prs2code /* external representation of the plan */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_prs2stub
|
||
|
oid prs2relid /* class to which this rule applies */
|
||
|
bool prs2islast /* is this the last stub fragment? */
|
||
|
int4 prs2no /* stub fragment number */
|
||
|
stub prs2stub /* stub fragment */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_rewrite
|
||
|
NameData rulename /* rule name */
|
||
|
char ev_type /* event type:
|
||
|
RETRIEVE, REPLACE, APPEND, DELETE
|
||
|
codes are parser-dependent (!?) */
|
||
|
oid ev_class /* class to which this rule applies */
|
||
|
int2 ev_attr /* attribute to which this rule applies */
|
||
|
bool is_instead /* is this an "instead" rule? */
|
||
|
text ev_qual /* qualification with which to modify
|
||
|
(rewrite) the plan that triggered this
|
||
|
rule */
|
||
|
text action /* parse tree of action */
|
||
|
.fi
|
||
|
.SH "LARGE OBJECT CATALOGS"
|
||
|
.nf M
|
||
|
pg_lobj
|
||
|
oid ourid /* 'ourid' from pg_naming that
|
||
|
identifies this object in the
|
||
|
Inversion file system namespace */
|
||
|
int4 objtype /* storage type code:
|
||
|
0=Inversion
|
||
|
1=Unix
|
||
|
2=External
|
||
|
3=Jaquith */
|
||
|
bytea object_descripto/* opaque object-handle structure */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_naming
|
||
|
NameData filename /* filename component */
|
||
|
oid ourid /* random oid used to identify this
|
||
|
instance in other instances (can't
|
||
|
use the actual oid for obscure
|
||
|
reasons */
|
||
|
oid parentid /* pg_naming instance of parent
|
||
|
Inversion file system directory */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_platter
|
||
|
NameData plname /* platter name */
|
||
|
int4 plstart /* the highest OCCUPIED extent */
|
||
|
.fi
|
||
|
.nf M
|
||
|
pg_plmap
|
||
|
oid plid /* platter (in pg_platter) on which
|
||
|
this extent (of blocks) resides */
|
||
|
oid pldbid /* database of the class to which this
|
||
|
extent (of blocks) belongs */
|
||
|
oid plrelid /* class to which this extend (of
|
||
|
blocks) belongs */
|
||
|
int4 plblkno /* starting block number within the
|
||
|
class */
|
||
|
int4 ploffset /* offset within the platter at which
|
||
|
this extent begins */
|
||
|
int4 plextentsz /* length of this extent */
|
||
|
.fi
|