目前大多数商业数据库(DB2, SQL Server)的并发控制采用的是两阶段锁(Two-Phase Locking,2PL)协议,2PL保证了并发事务执行的可串行化。
两段锁协议
2PL在对任何数据进行读、写操作之前,需要对该数据加锁。在封锁相容矩阵中,S锁(Share Locks,共享锁)和X锁(Exclusive Locks,排它锁)是不相容的,因此当事务1正对数据A进行读操作(加S锁)时,事务2想要对数据进行写操作(加X锁),那么事务2必须等待事务1释放数据A上的S锁,才能继续执行。
MVCC
在多用户环境中,PostgreSQL使用多版本并发控制(Multi-version Concurrency Control,MVCC)和多种锁相结合来维护数据的一致性。
https://blog.csdn.net/tencupofkaiwater/article/details/88402928