javax.persistence.RollbackException:标记为rollbackOnly的事务

我正在与Spring MVC进行游戏 . 我有一个获取游戏和更新的方法但是当它进行更新它会给出错误,这是代码:

HomeController.class

@Transactional
@RequestMapping(value = "/partida/{idPartida}", method = RequestMethod.GET)
public String getPartida(@PathVariable("idPartida") long idPartida,
        Model model) throws IOException {
    Partida p = ServicioAplicacionPartida.getPartida(entityManager,
            idPartida);

    if (p.getJson() == null) {
        p.inicializarPartida(entityManager);
        ServicioAplicacionPartida.update(entityManager, p);
    }

GameDAO.class

@Transactional
public static Partida update(EntityManager entityManager, Partida p) {
    try {               
        Query q = entityManager.createNativeQuery("update Partida p SET p.json=:json where p.id=:id");
        q.setParameter("json", p.getJson());
        q.setParameter("id", p.getId());
        q.executeUpdate();
        return entityManager.find(Partida.class, p.getId());
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

执行“q.executeUdate()”行时发生错误,这里是:

javax.persistence.PersistenceException:org.hibernate.exception.DataException:无法执行语句

这是服务器错误:

Estado HTTP 500 - 请求处理失败;嵌套异常是org.springframework.transaction.TransactionSystemException:无法提交JPA事务;嵌套异常是javax.persistence.RollbackException:标记为rollbackOnly的事务

我该怎么办才能解决这个问题?

回答(1)

2 years ago

你有注释控制器和DAO方法作为@Transactional,它是不正确的,因为@Transactional可以继承到内部方法 . 通常,事务应该从服务层开始 .

尝试将这些参数添加到@Transactional注释并从Controller或DAO中删除它:

@Transactional(readOnly = false, propagation = Propagation.REQUIRED, rollbackFor=Exception.class)