java EntityManager在尝试删除同一事务中锁定的实体时引发OptimisticLockException
这是我的代码:
EntityManager em = JPAUtil.createEntityManager();
try {
EntityTransaction tx = em.getTransaction();
try {
//do some stuff here
tx.begin();
List es = em.createNamedQuery("getMyEntities", MyEntity.class).getResultList();
for (MyEntity e : es) {
em.lock(e, LockModeType.OPTIMISTIC);
}
if (es.size() != 0) {
em.remove(es.get(0));
}
tx.commit
} finally {
if (tx.isActive()) {
tx.rollback();
}
}
} finally {
em.close();
}
当我执行代码时,我得到:
..........
Caused by: javax.persistence.OptimisticLockException: Newer version [null] of entity [[MyEntity#63]] found in database
at org.hibernate.ejb.AbstractEntityManagerImpl.wrapLockException(AbstractEntityManagerImpl.java:1427)
at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1324)
at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1300)
at org.hibernate.ejb.TransactionImpl.commit(TransactionImpl.java:80)
... 23 more
有人能解释为什么吗
# 1 楼答案
我认为这个错误是因为我试图删除一个有锁的记录。尝试删除此行时,会将版本设置为
null
,但数据库中的版本仍然设置为前一个数字。hibernate core似乎认为null
值对于这种操作不可靠如果我必须做这种操作,我必须首先释放这个实体上的锁
任何对此有更好了解的人都必须澄清这个问题