首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PESSIMISTIC_WRITE会锁定整张桌子吗?

PESSIMISTIC_WRITE会锁定整张桌子吗?
EN

Stack Overflow用户
提问于 2018-03-07 08:22:18
回答 1查看 6.5K关注 0票数 13

只是为了确保我正确地理解了事情是如何运作的。

如果我做了em.lock(employee, LockModeType.PESSIMISTIC_WRITE); -它是只阻塞这个实体(employee)还是整个表Employees

如果有关系的话,我说的是PostgreSQL

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-03-07 12:40:24

它只应该阻止实体。

PostgreSQL hibernate方言在写锁的情况下添加for updatehttps://github.com/hibernate/hibernate-orm/blob/master/hibernate-core/src/main/java/org/hibernate/dialect/PostgreSQL81Dialect.java#L549 (更新版本只使用相同的实现)

for update由PostgreSQL:https://www.postgresql.org/docs/9.5/static/explicit-locking.html按行处理。

对于update,SELECT语句检索的行会像UPDATE一样被锁定。这将防止它们被其他事务锁定、修改或删除,直到当前事务结束为止。也就是说,尝试UPDATE、DELETE、SELECT FOR UPDATE、SELECT FOR KEY UPDATE、SELECT FOR SHARE或SELECT FOR KEY共享的事务将被阻塞,直到当前事务结束;反之,SELECT FOR UPDATE将等待在同一行上运行任何这些命令的并发事务,然后锁定并返回已更新的行(如果删除该行,则不会返回行)。

票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49147149

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档