尽管 PostgreSQL 为表数据提供了非阻塞的读写访问,但 PostgreSQL 当前实现的索引访问方法并不是每一种都能提供非阻塞的读写访问。各种索引类型的处理方式如下:
读写访问使用短期的页级共享/排他锁。每个索引行在被取出或插入之后,锁都会立即释放。这些索引类型在不存在死锁条件的前提下提供了最高的并发性。
读写访问使用的是 Hash 桶级共享/排他锁。锁会在整个 Hash 桶处理完成后释放。桶级锁比索引级锁具有更好的并发性,但也可能产生死锁,因为它们的持有时间比一次索引操作更长。
读写访问使用短期的页级共享/排他锁。每个索引行在被取出或插入之后,锁都会立即释放。但要注意,插入一个 GIN 索引值通常会导致每行产生多个索引键插入,因此 GIN 可能为了插入单个值而做大量工作。
目前,B-树索引为并发应用提供了最佳性能;由于它们还比 Hash 索引拥有更多特性,因此对于需要为标量数据建立索引的并发应用,推荐使用 B-树索引类型。处理非标量数据时,B-树就不再适用,此时应改用 GiST、SP-GiST 或 GIN 索引。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。