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