🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
# 13.1\. 介绍 PostgreSQL为开发者提供了丰富的对数据并发访问进行管理的工具。 在内部,PostgreSQL利用多版本并发控制(MVCC)来维护数据的一致性。 这就意味着当检索数据时,每个事务看到的都只是一小段时间之前的数据快照(一个_数据库版本_), 而不是数据的当前状态。这样,如果对每个数据库会话进行_事务隔离_,就可以避免一个事务看到其它并发事务的更新而导致不一致的数据。MVCC通过避开传统数据库系统锁定的方法,最大限度地减少锁竞争以允许合理的多用户环境中的性能。 使用多版本并发控制比锁定模型的主要优点是在MVCC里, 对检索(读)数据的锁请求与写数据的锁请求不冲突,所以读不会阻塞写,而写也从不阻塞读。甚至当通过创新的_序列化快照隔离_ (SSI)级别提供事务隔离的严格等级时, PostgreSQL维持这样的保证。 在PostgreSQL里也有表和行级别的锁定机制,用于给那些无法轻松接受MVCC行为的应用。 不过,恰当地使用MVCC总会提供比锁更好的性能。另外,由应用定义的咨询锁提供了一个获得不依赖于单独事务的锁的机制。