lmgr.h

来自「PostgreSQL7.4.6 for Linux」· C头文件 代码 · 共 67 行

H
67
字号
/*------------------------------------------------------------------------- * * lmgr.h *	  POSTGRES lock manager definitions. * * * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $Id: lmgr.h,v 1.40 2003/09/04 22:06:27 tgl Exp $ * *------------------------------------------------------------------------- */#ifndef LMGR_H#define LMGR_H#include "storage/lock.h"#include "utils/rel.h"/* These are the valid values of type LOCKMODE: *//* NoLock is not a lock mode, but a flag value meaning "don't get a lock" */#define NoLock					0#define AccessShareLock			1		/* SELECT */#define RowShareLock			2		/* SELECT FOR UPDATE */#define RowExclusiveLock		3		/* INSERT, UPDATE, DELETE */#define ShareUpdateExclusiveLock 4		/* VACUUM (non-FULL) */#define ShareLock				5		/* CREATE INDEX */#define ShareRowExclusiveLock	6		/* like EXCLUSIVE MODE, but allows										 * ROW SHARE */#define ExclusiveLock			7		/* blocks ROW SHARE/SELECT...FOR										 * UPDATE */#define AccessExclusiveLock		8		/* ALTER TABLE, DROP TABLE, VACUUM										 * FULL, and unqualified LOCK										 * TABLE *//* * Note: all lock mode numbers must be less than lock.h's MAX_LOCKMODES, * so increase that if you want to add more modes. */extern LOCKMETHOD LockTableId;extern LOCKMETHOD InitLockTable(int maxBackends);extern void RelationInitLockInfo(Relation relation);/* Lock a relation */extern void LockRelation(Relation relation, LOCKMODE lockmode);extern bool ConditionalLockRelation(Relation relation, LOCKMODE lockmode);extern void UnlockRelation(Relation relation, LOCKMODE lockmode);extern void LockRelationForSession(LockRelId *relid, LOCKMODE lockmode);extern void UnlockRelationForSession(LockRelId *relid, LOCKMODE lockmode);/* Lock a page (mainly used for indexes) */extern void LockPage(Relation relation, BlockNumber blkno, LOCKMODE lockmode);extern bool ConditionalLockPage(Relation relation, BlockNumber blkno, LOCKMODE lockmode);extern void UnlockPage(Relation relation, BlockNumber blkno, LOCKMODE lockmode);/* Lock an XID (used to wait for a transaction to finish) */extern void XactLockTableInsert(TransactionId xid);extern void XactLockTableWait(TransactionId xid);#endif   /* LMGR_H */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?