mirror of
https://github.com/postgres/postgres.git
synced 2026-03-21 01:50:42 -04:00
For those system catalogs that have a unique indexes, make a primary key and unique constraint, using ALTER TABLE ... PRIMARY KEY/UNIQUE USING INDEX. This can be helpful for GUI tools that look for a primary key, and it might in the future allow declaring foreign keys, for making schema diagrams. The constraint creation statements are automatically created by genbki.pl from DECLARE_UNIQUE_INDEX directives. To specify which one of the available unique indexes is the primary key, use the new directive DECLARE_UNIQUE_INDEX_PKEY instead. By convention, we usually make a catalog's OID column its primary key, if it has one. Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us> Discussion: https://www.postgresql.org/message-id/flat/dc5f44d9-5ec1-a596-0251-dadadcdede98@2ndquadrant.com
66 lines
2.1 KiB
C
66 lines
2.1 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* pg_replication_origin.h
|
|
* definition of the "replication origin" system catalog
|
|
* (pg_replication_origin)
|
|
*
|
|
* Portions Copyright (c) 1996-2021, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
*
|
|
* src/include/catalog/pg_replication_origin.h
|
|
*
|
|
* NOTES
|
|
* The Catalog.pm module reads this file and derives schema
|
|
* information.
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef PG_REPLICATION_ORIGIN_H
|
|
#define PG_REPLICATION_ORIGIN_H
|
|
|
|
#include "access/xlogdefs.h"
|
|
#include "catalog/genbki.h"
|
|
#include "catalog/pg_replication_origin_d.h"
|
|
|
|
/* ----------------
|
|
* pg_replication_origin. cpp turns this into
|
|
* typedef struct FormData_pg_replication_origin
|
|
* ----------------
|
|
*/
|
|
CATALOG(pg_replication_origin,6000,ReplicationOriginRelationId) BKI_SHARED_RELATION
|
|
{
|
|
/*
|
|
* Locally known id that get included into WAL.
|
|
*
|
|
* This should never leave the system.
|
|
*
|
|
* Needs to fit into an uint16, so we don't waste too much space in WAL
|
|
* records. For this reason we don't use a normal Oid column here, since
|
|
* we need to handle allocation of new values manually.
|
|
*/
|
|
Oid roident;
|
|
|
|
/*
|
|
* Variable-length fields start here, but we allow direct access to
|
|
* roname.
|
|
*/
|
|
|
|
/* external, free-format, name */
|
|
text roname BKI_FORCE_NOT_NULL;
|
|
|
|
#ifdef CATALOG_VARLEN /* further variable-length fields */
|
|
#endif
|
|
} FormData_pg_replication_origin;
|
|
|
|
typedef FormData_pg_replication_origin *Form_pg_replication_origin;
|
|
|
|
DECLARE_TOAST(pg_replication_origin, 4181, 4182);
|
|
#define PgReplicationOriginToastTable 4181
|
|
#define PgReplicationOriginToastIndex 4182
|
|
|
|
DECLARE_UNIQUE_INDEX_PKEY(pg_replication_origin_roiident_index, 6001, on pg_replication_origin using btree(roident oid_ops));
|
|
#define ReplicationOriginIdentIndex 6001
|
|
DECLARE_UNIQUE_INDEX(pg_replication_origin_roname_index, 6002, on pg_replication_origin using btree(roname text_ops));
|
|
#define ReplicationOriginNameIndex 6002
|
|
|
|
#endif /* PG_REPLICATION_ORIGIN_H */
|