我理解PostgreSQL插入使用ROW EXCLUSIVE锁,这是否意味着插入可以并行,并且一个插入不会锁定整个表?
有问题的表有一个在DB之外生成的主键,没有其他索引(但我很好奇,如果不是这样的话会发生什么)。
修改1:
根据文档,ROW EXCLUSIVE与CREARE INDEX获取的SHARE冲突。
这是否意味着如果表有索引,insert会锁定整个表吗?
或者只有在第一次创建索引时才会锁定表吗?
另外,据我所知,主键也是一个索引,对吗?
答案 0 :(得分:10)
并发插入不应该相互阻塞,除非它们将冲突的密钥插入到唯一索引中,在这种情况下,第二个插入将等待包含第一个的事务被提交或回滚,然后中止或继续。主键实现为唯一索引。
非唯一索引不应导致其他锁定冲突。创建索引将阻止对表的插入和更新,尽管您可以在命令中添加concurrently
以避免这种情况,但速度会有所降低。