📄 lmgr.h
字号:
/*------------------------------------------------------------------------- * * lmgr.h * POSTGRES lock manager definitions. * * * Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $PostgreSQL: pgsql/src/include/storage/lmgr.h,v 1.52 2005/10/15 02:49:46 momjian 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/FOR SHARE */#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 void InitLockTable(void);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, bool istemprel, LOCKMODE lockmode);extern void UnlockRelationForSession(LockRelId *relid, LOCKMODE lockmode);/* Lock a relation for extension */extern void LockRelationForExtension(Relation relation, LOCKMODE lockmode);extern void UnlockRelationForExtension(Relation relation, LOCKMODE lockmode);/* Lock a page (currently only used within 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 a tuple (see heap_lock_tuple before assuming you understand this) */extern void LockTuple(Relation relation, ItemPointer tid, LOCKMODE lockmode);extern bool ConditionalLockTuple(Relation relation, ItemPointer tid, LOCKMODE lockmode);extern void UnlockTuple(Relation relation, ItemPointer tid, LOCKMODE lockmode);/* Lock an XID (used to wait for a transaction to finish) */extern void XactLockTableInsert(TransactionId xid);extern void XactLockTableDelete(TransactionId xid);extern void XactLockTableWait(TransactionId xid);extern bool ConditionalXactLockTableWait(TransactionId xid);/* Lock a general object (other than a relation) of the current database */extern void LockDatabaseObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode);extern void UnlockDatabaseObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode);/* Lock a shared-across-databases object (other than a relation) */extern void LockSharedObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode);extern void UnlockSharedObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode);#endif /* LMGR_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -