加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL中的ROW EXCLUSIVE究竟是什么?

发布时间:2020-12-13 18:03:58 所属栏目:百科 来源:网络整理
导读:我知道PostgreSQL插入使用ROW EXCLUSIVE锁,这是否意味着插入可以并行,并且一个插入不会锁定整个表? 有问题的表有一个在DB之外生成的主键,没有其他索引(但我很好奇如果不是这样会发生什么). 编辑1: 根据文档,ROW EXCLUSIVE与CREARE INDEX获得的SHARE冲突.
我知道PostgreSQL插入使用ROW EXCLUSIVE锁,这是否意味着插入可以并行,并且一个插入不会锁定整个表?

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

编辑1:

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

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

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

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读