mirror of
https://git.postgresql.org/git/postgresql.git
synced 2026-02-15 10:57:02 +08:00
This removes ATChangeIndexesPersistence() introduced by f41872d0c1239d36
which was too ugly to live for long. Instead, the correct persistence
marking is passed all the way down to reindex_index, so that the
transient relation built to contain the index relfilenode can
get marked correctly right from the start.
Author: Fabrízio de Royes Mello
Review and editorialization by Michael Paquier
and Álvaro Herrera
40 lines
1.2 KiB
C
40 lines
1.2 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* cluster.h
|
|
* header file for postgres cluster command stuff
|
|
*
|
|
* Portions Copyright (c) 1996-2014, PostgreSQL Global Development Group
|
|
* Portions Copyright (c) 1994-5, Regents of the University of California
|
|
*
|
|
* src/include/commands/cluster.h
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
#ifndef CLUSTER_H
|
|
#define CLUSTER_H
|
|
|
|
#include "nodes/parsenodes.h"
|
|
#include "storage/lock.h"
|
|
#include "utils/relcache.h"
|
|
|
|
|
|
extern void cluster(ClusterStmt *stmt, bool isTopLevel);
|
|
extern void cluster_rel(Oid tableOid, Oid indexOid, bool recheck,
|
|
bool verbose);
|
|
extern void check_index_is_clusterable(Relation OldHeap, Oid indexOid,
|
|
bool recheck, LOCKMODE lockmode);
|
|
extern void mark_index_clustered(Relation rel, Oid indexOid, bool is_internal);
|
|
|
|
extern Oid make_new_heap(Oid OIDOldHeap, Oid NewTableSpace, char relpersistence,
|
|
LOCKMODE lockmode);
|
|
extern void finish_heap_swap(Oid OIDOldHeap, Oid OIDNewHeap,
|
|
bool is_system_catalog,
|
|
bool swap_toast_by_content,
|
|
bool check_constraints,
|
|
bool is_internal,
|
|
TransactionId frozenXid,
|
|
MultiXactId minMulti,
|
|
char newrelpersistence);
|
|
|
|
#endif /* CLUSTER_H */
|