1996-08-28 03:59:28 +02:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
*
|
|
|
|
* rel.h--
|
1997-09-07 07:04:48 +02:00
|
|
|
* POSTGRES relation descriptor definitions.
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
*
|
|
|
|
* Copyright (c) 1994, Regents of the University of California
|
|
|
|
*
|
1998-01-24 23:50:57 +01:00
|
|
|
* $Id: rel.h,v 1.16 1998/01/24 22:50:54 momjian Exp $
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
1997-09-07 07:04:48 +02:00
|
|
|
#ifndef REL_H
|
1996-08-28 03:59:28 +02:00
|
|
|
#define REL_H
|
|
|
|
|
1996-11-04 12:51:27 +01:00
|
|
|
#include <catalog/pg_am.h>
|
|
|
|
#include <catalog/pg_class.h>
|
1996-11-04 08:46:06 +01:00
|
|
|
#include <access/strat.h>
|
|
|
|
#include <access/tupdesc.h>
|
1996-11-04 12:51:27 +01:00
|
|
|
#include <rewrite/prs2lock.h>
|
1996-11-04 08:46:06 +01:00
|
|
|
#include <storage/fd.h>
|
1996-08-28 03:59:28 +02:00
|
|
|
|
1997-09-07 07:04:48 +02:00
|
|
|
typedef struct Trigger
|
|
|
|
{
|
1997-09-08 04:41:22 +02:00
|
|
|
char *tgname;
|
|
|
|
Oid tgfoid;
|
1998-01-15 20:46:37 +01:00
|
|
|
FmgrInfo tgfunc;
|
1997-09-08 04:41:22 +02:00
|
|
|
int16 tgtype;
|
|
|
|
int16 tgnargs;
|
|
|
|
int16 tgattr[8];
|
|
|
|
char **tgargs;
|
1997-09-08 23:56:23 +02:00
|
|
|
} Trigger;
|
1997-09-07 07:04:48 +02:00
|
|
|
|
|
|
|
typedef struct TriggerDesc
|
|
|
|
{
|
1997-09-08 04:41:22 +02:00
|
|
|
uint16 n_before_statement[4];
|
|
|
|
uint16 n_before_row[4];
|
|
|
|
uint16 n_after_row[4];
|
|
|
|
uint16 n_after_statement[4];
|
|
|
|
Trigger **tg_before_statement[4];
|
|
|
|
Trigger **tg_before_row[4];
|
|
|
|
Trigger **tg_after_row[4];
|
|
|
|
Trigger **tg_after_statement[4];
|
|
|
|
Trigger *triggers;
|
1997-09-08 23:56:23 +02:00
|
|
|
} TriggerDesc;
|
1997-09-07 07:04:48 +02:00
|
|
|
|
|
|
|
typedef struct RelationData
|
|
|
|
{
|
1997-09-08 04:41:22 +02:00
|
|
|
File rd_fd; /* open file descriptor */
|
|
|
|
int rd_nblocks; /* number of blocks in rel */
|
|
|
|
uint16 rd_refcnt; /* reference count */
|
|
|
|
bool rd_islocal; /* uses the local buffer mgr */
|
|
|
|
bool rd_isnailed; /* rel is nailed in cache */
|
|
|
|
bool rd_istemp; /* rel is a temp rel */
|
|
|
|
bool rd_tmpunlinked; /* temp rel already unlinked */
|
|
|
|
Form_pg_am rd_am; /* AM tuple */
|
|
|
|
Form_pg_class rd_rel; /* RELATION tuple */
|
|
|
|
Oid rd_id; /* relations's object id */
|
|
|
|
Pointer lockInfo; /* ptr. to misc. info. */
|
|
|
|
TupleDesc rd_att; /* tuple desciptor */
|
|
|
|
RuleLock *rd_rules; /* rewrite rules */
|
|
|
|
IndexStrategy rd_istrat;
|
|
|
|
RegProcedure *rd_support;
|
|
|
|
TriggerDesc *trigdesc;
|
1997-09-08 23:56:23 +02:00
|
|
|
} RelationData;
|
1997-09-07 07:04:48 +02:00
|
|
|
|
|
|
|
typedef RelationData *Relation;
|
1996-08-28 03:59:28 +02:00
|
|
|
|
|
|
|
/* ----------------
|
1997-09-07 07:04:48 +02:00
|
|
|
* RelationPtr is used in the executor to support index scans
|
|
|
|
* where we have to keep track of several index relations in an
|
|
|
|
* array. -cim 9/10/89
|
1996-08-28 03:59:28 +02:00
|
|
|
* ----------------
|
|
|
|
*/
|
1997-09-07 07:04:48 +02:00
|
|
|
typedef Relation *RelationPtr;
|
1996-08-28 03:59:28 +02:00
|
|
|
|
1997-09-07 07:04:48 +02:00
|
|
|
#define InvalidRelation ((Relation)NULL)
|
1996-08-28 03:59:28 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationIsValid --
|
1997-09-07 07:04:48 +02:00
|
|
|
* True iff relation descriptor is valid.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
1997-09-07 07:04:48 +02:00
|
|
|
#define RelationIsValid(relation) PointerIsValid(relation)
|
1996-08-28 03:59:28 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetSystemPort --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns system port of a relation.
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
* Note:
|
1997-09-07 07:04:48 +02:00
|
|
|
* Assumes relation descriptor is valid.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationGetSystemPort(relation) ((relation)->rd_fd)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetLockInfo --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns the lock information structure in the reldesc
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
#define RelationGetLockInfo(relation) ((relation)->lockInfo)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationHasReferenceCountZero --
|
1997-09-07 07:04:48 +02:00
|
|
|
* True iff relation reference count is zero.
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
* Note:
|
1997-09-07 07:04:48 +02:00
|
|
|
* Assumes relation descriptor is valid.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationHasReferenceCountZero(relation) \
|
1997-09-07 07:04:48 +02:00
|
|
|
((bool)((relation)->rd_refcnt == 0))
|
1996-08-28 03:59:28 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationSetReferenceCount --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Sets relation reference count.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationSetReferenceCount(relation,count) ((relation)->rd_refcnt = count)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationIncrementReferenceCount --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Increments relation reference count.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationIncrementReferenceCount(relation) ((relation)->rd_refcnt += 1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationDecrementReferenceCount --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Decrements relation reference count.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationDecrementReferenceCount(relation) ((relation)->rd_refcnt -= 1)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetAccessMethodTupleForm --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns access method attribute values for a relation.
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
* Note:
|
1997-09-07 07:04:48 +02:00
|
|
|
* Assumes relation descriptor is valid.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationGetAccessMethodTupleForm(relation) ((relation)->rd_am)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetRelationTupleForm --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns relation attribute values for a relation.
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
* Note:
|
1997-09-07 07:04:48 +02:00
|
|
|
* Assumes relation descriptor is valid.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationGetRelationTupleForm(relation) ((relation)->rd_rel)
|
|
|
|
|
|
|
|
|
1997-09-07 07:04:48 +02:00
|
|
|
/*
|
1996-08-28 03:59:28 +02:00
|
|
|
* RelationGetRelationId --
|
|
|
|
*
|
1997-09-07 07:04:48 +02:00
|
|
|
* returns the object id of the relation
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
#define RelationGetRelationId(relation) ((relation)->rd_id)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetFile --
|
|
|
|
*
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns the open File decscriptor
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationGetFile(relation) ((relation)->rd_fd)
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetRelationName --
|
|
|
|
*
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns a Relation Name
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationGetRelationName(relation) (&(relation)->rd_rel->relname)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetRelationName --
|
|
|
|
*
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns a the number of attributes.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationGetNumberOfAttributes(relation) ((relation)->rd_rel->relnatts)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* RelationGetTupleDescriptor --
|
1997-09-07 07:04:48 +02:00
|
|
|
* Returns tuple descriptor for a relation.
|
1996-08-28 03:59:28 +02:00
|
|
|
*
|
|
|
|
* Note:
|
1997-09-07 07:04:48 +02:00
|
|
|
* Assumes relation descriptor is valid.
|
1996-08-28 03:59:28 +02:00
|
|
|
*/
|
|
|
|
#define RelationGetTupleDescriptor(relation) ((relation)->rd_att)
|
|
|
|
|
|
|
|
extern IndexStrategy RelationGetIndexStrategy(Relation relation);
|
|
|
|
|
1998-01-24 23:50:57 +01:00
|
|
|
extern void RelationSetIndexSupport(Relation relation, IndexStrategy strategy,
|
1997-09-08 23:56:23 +02:00
|
|
|
RegProcedure *support);
|
1997-09-07 07:04:48 +02:00
|
|
|
|
|
|
|
#endif /* REL_H */
|