PostgreSQL Source Code git master
pg_inherits.h
Go to the documentation of this file.
1/*-------------------------------------------------------------------------
2 *
3 * pg_inherits.h
4 * definition of the "inherits" system catalog (pg_inherits)
5 *
6 *
7 * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
8 * Portions Copyright (c) 1994, Regents of the University of California
9 *
10 * src/include/catalog/pg_inherits.h
11 *
12 * NOTES
13 * The Catalog.pm module reads this file and derives schema
14 * information.
15 *
16 *-------------------------------------------------------------------------
17 */
18#ifndef PG_INHERITS_H
19#define PG_INHERITS_H
20
21#include "catalog/genbki.h"
22#include "catalog/pg_inherits_d.h" /* IWYU pragma: export */
23
24#include "nodes/pg_list.h"
25#include "storage/lock.h"
26
27/* ----------------
28 * pg_inherits definition. cpp turns this into
29 * typedef struct FormData_pg_inherits
30 * ----------------
31 */
32CATALOG(pg_inherits,2611,InheritsRelationId)
33{
34 Oid inhrelid BKI_LOOKUP(pg_class);
35 Oid inhparent BKI_LOOKUP(pg_class);
36 int32 inhseqno;
37 bool inhdetachpending;
39
40/* ----------------
41 * Form_pg_inherits corresponds to a pointer to a tuple with
42 * the format of pg_inherits relation.
43 * ----------------
44 */
46
47DECLARE_UNIQUE_INDEX_PKEY(pg_inherits_relid_seqno_index, 2680, InheritsRelidSeqnoIndexId, pg_inherits, btree(inhrelid oid_ops, inhseqno int4_ops));
48DECLARE_INDEX(pg_inherits_parent_index, 2187, InheritsParentIndexId, pg_inherits, btree(inhparent oid_ops));
49
50
51extern List *find_inheritance_children(Oid parentrelId, LOCKMODE lockmode);
52extern List *find_inheritance_children_extended(Oid parentrelId, bool omit_detached,
53 LOCKMODE lockmode, bool *detached_exist, TransactionId *detached_xmin);
54
55extern List *find_all_inheritors(Oid parentrelId, LOCKMODE lockmode,
56 List **numparents);
57extern bool has_subclass(Oid relationId);
58extern bool has_superclass(Oid relationId);
59extern bool typeInheritsFrom(Oid subclassTypeId, Oid superclassTypeId);
60extern void StoreSingleInheritance(Oid relationId, Oid parentOid,
61 int32 seqNumber);
62extern bool DeleteInheritsTuple(Oid inhrelid, Oid inhparent,
63 bool expect_detach_pending,
64 const char *childname);
65extern bool PartitionHasPendingDetach(Oid partoid);
66
67#endif /* PG_INHERITS_H */
int32_t int32
Definition: c.h:484
uint32 TransactionId
Definition: c.h:609
#define BKI_LOOKUP(catalog)
Definition: genbki.h:46
int LOCKMODE
Definition: lockdefs.h:26
FormData_pg_inherits
Definition: pg_inherits.h:38
FormData_pg_inherits * Form_pg_inherits
Definition: pg_inherits.h:45
List * find_all_inheritors(Oid parentrelId, LOCKMODE lockmode, List **numparents)
Definition: pg_inherits.c:255
bool has_subclass(Oid relationId)
Definition: pg_inherits.c:355
bool DeleteInheritsTuple(Oid inhrelid, Oid inhparent, bool expect_detach_pending, const char *childname)
Definition: pg_inherits.c:552
DECLARE_UNIQUE_INDEX_PKEY(pg_inherits_relid_seqno_index, 2680, InheritsRelidSeqnoIndexId, pg_inherits, btree(inhrelid oid_ops, inhseqno int4_ops))
DECLARE_INDEX(pg_inherits_parent_index, 2187, InheritsParentIndexId, pg_inherits, btree(inhparent oid_ops))
List * find_inheritance_children(Oid parentrelId, LOCKMODE lockmode)
Definition: pg_inherits.c:58
void StoreSingleInheritance(Oid relationId, Oid parentOid, int32 seqNumber)
Definition: pg_inherits.c:508
List * find_inheritance_children_extended(Oid parentrelId, bool omit_detached, LOCKMODE lockmode, bool *detached_exist, TransactionId *detached_xmin)
Definition: pg_inherits.c:82
bool has_superclass(Oid relationId)
Definition: pg_inherits.c:377
bool typeInheritsFrom(Oid subclassTypeId, Oid superclassTypeId)
Definition: pg_inherits.c:406
bool PartitionHasPendingDetach(Oid partoid)
Definition: pg_inherits.c:620
CATALOG(pg_inherits, 2611, InheritsRelationId)
Definition: pg_inherits.h:32
unsigned int Oid
Definition: postgres_ext.h:32
Definition: pg_list.h:54