JPA Hibernate слияние выполняет вставку вместо обновления - PullRequest
15 голосов
/ 24 февраля 2011

У меня есть простой тест, в котором я пытаюсь обновить объект, но слияние, кажется, выполняет вставку вместо обновления.

@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

1 Ответ

24 голосов
/ 01 марта 2011

У меня был столбец версии, который не был установлен, когда начальные данные были вставлены в базу данных. Отсюда и все проблемы с обновлением и удалением

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...