我有一个简单的测试,我试图更新对象,但合并似乎是执行插入而不是更新。
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:spring/app-context.xml","classpath:spring/testdb-context.xml"})
public class UserJPATest {
@Test
public void testUpdate() throws Exception {
System.out.println("update");
User entity = ObjectManager.USER_DAO.findById(3L);
entity.setUsername("harryUpdate");
ObjectManager.USER_DAO.update(entity);
User selEntity = ObjectManager.USER_DAO.findById(3L);
Assert.assertEquals(entity.getUsername(),selEntity.getUsername());
}
}
这是我的更新方法
@Override
@Transactional(propagation= Propagation.REQUIRES_NEW)
public T update(T entity) throws Exception {
try {
T merged = entityManager.merge(entity);
return merged;
} catch (Exception e) {
e.printStackTrace();
throw new Exception(e);
}
}
更新代码
@Override
@Transactional(propagation= Propagation.REQUIRES_NEW)
public T update(T entity) throws Exception {
try {
T merged = null;
BaseEntity baseEntity = null;
if(entity instanceof BaseEntity){
baseEntity = (BaseEntity)entity;
merged = entityManager.find(entityClass, baseEntity.getId());
}
merged = entityManager.merge(entity);
entityManager.flush();
return merged;
} catch (Exception e) {
e.printStackTrace();
throw new Exception(e);
}
}
现在我收到以下错误无法提交JPA事务;嵌套异常是javax.persistence.RollbackException:事务标记为rollbackOnly
答案 0 :(得分:24)
我有一个版本列,当种子数据插入数据库时没有设置。因此更新和删除所有问题
答案 1 :(得分:0)
Merge 只会在它在数据库中找到该 id 时更新该行,因此如果您创建一个新对象并忘记将其 ID 设置为所需行的相同 ID,它将尝试插入一个新对象。如果您的数据库表没有任何唯一字段,则此插入可能会成功,因为不会出现 sql 错误。
一旦我使用该行的 ID 设置新对象,我就能够更新所需的行。