9.3 9.4 9.5 9.6 10 11 12 13 14 15 16 17 Current(18)
PostgreSQL中文社区 问题报告 纠错本页面

13.7. 锁定和索引 #

尽管PostgreSQL提供对表数据访问的非阻塞读/写,但并非PostgreSQL中实现的每一个索引访问方法当前都能够提供非阻塞读/写访问。不同的索引类型按照下面方法操作:

B-tree、GiSTSP-GiST索引

短期的页面级共享/排他锁被用于读/写访问。每个索引行被获取或被插入后立即释放锁。这些索引类型提供了无死锁情况的最高并发性。

Hash索引

Hash桶级别的共享/排他锁被用于读/写访问。锁在整个Hash桶处理完成后释放。Hash桶级锁比索引级的锁提供了更好的并发性,但是可能产生死锁,因为锁持有的时间比一次索引操作时间长。

GIN索引

短期的页面级共享/排他锁被用于读/写访问。锁在索引行被插入/获取后立即释放。但要注意的是一个GIN索引值的插入通常导致对每行产生几个索引键的插入,因此GIN可能为了插入一个单一值而做大量的工作。

目前,B-tree索引为并发应用提供了最好的性能。因为它还有比Hash索引更多的特性,在那些需要对标量数据进行索引的并发应用中,我们建议使用B-tree索引类型。在处理非标量数据时,B-tree就没什么用了,应该使用GiST、SP-GiST或GIN索引替代。