我正在与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 回答
你有注释控制器和DAO方法作为@Transactional,它是不正确的,因为@Transactional可以继承到内部方法 . 通常,事务应该从服务层开始 .
尝试将这些参数添加到@Transactional注释并从Controller或DAO中删除它: