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

如何使用JPA / Hibernate在数据库中处理具有唯一约束的多线程插入?

如何解决如何使用JPA / Hibernate在数据库中处理具有唯一约束的多线程插入?

| 在消息驱动的Bean中,我将条目保留到具有唯一条目的查找表中。基本上,我使用条件api创建一个select语句,如果找不到条目,​​则创建一个条目。 当前,此代码正在运行MysqL错误,因为在某些情况下,此条目的创建(
em.persist(entry)
)会违反数据库上的唯一约束。我的mdb的另一个实例在我找不到它之后并且可以创建它之前创建了查找条目。 我该如何处理这个同步问题,所以仍然只有一个条目?     

解决方法

您需要使用SELECT FOR UPDATE或以其他方式确保唯一性(例如,在Java内部生成条目的唯一部分)。 Hibernate支持悲观锁,我相信这只是同一件事的另一个名称。     

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