PostgreSQL中的ROW EXCLUSIVE究竟是什么?

时间:2013-01-25 21:03:29

标签: postgresql insert locking

我理解PostgreSQL插入使用ROW EXCLUSIVE锁,这是否意味着插入可以并行,并且一个插入不会锁定整个表?

有问题的表有一个在DB之外生成的主键,没有其他索引(但我很好奇,如果不是这样的话会发生什么)。

修改1:

根据文档,ROW EXCLUSIVE与CREARE INDEX获取的SHARE冲突。

这是否意味着如果表有索引,insert会锁定整个表吗?

或者只有在第一次创建索引时才会锁定表吗?

另外,据我所知,主键也是一个索引,对吗?

1 个答案:

答案 0 :(得分:10)

并发插入不应该相互阻塞,除非它们将冲突的密钥插入到唯一索引中,在这种情况下,第二个插入将等待包含第一个的事务被提交或回滚,然后中止或继续。主键实现为唯一索引。

非唯一索引不应导致其他锁定冲突。创建索引将阻止对表的插入和更新,尽管您可以在命令中添加concurrently以避免这种情况,但速度会有所降低。