微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PostgreSQL中的ROW EXCLUSIVE究竟是什么?

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

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

编辑1:

根据文档,ROW EXCLUSIVE与CREARE INDEX获得的SHARE冲突.

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

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

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐