我正在使用JPA 2 Hibernate实现和Spring MVC来管理事务
我正在使用通用DAO模式来管理数据库操作
当前,我们有一个单一方法的事务,例如:
someDao.save (someObject)
这是从JSF页面调用的@Transactional方法.
方法save是从Generic DAO继承的,它持久地存储到具有级联oneToMany关系的许多实体的数据库中,但是它必须在数据库中执行几千个插入语句,因此需要很长时间.
我想为用户提供一种取消操作的方法,但是到目前为止,我无法做到这一点,当我调用方法save()时,直到所有插入操作都执行完之后,才能取消该操作.
我试图抛出一些异常,以从注入的PersistenceContext回滚事务,但是它没有用,它只是以没有错误的方式结束了:(
显然,我不能从方法中引发异常,这只是我来源中的一个调用. JPA PersistenceContext做所有事情
有没有办法取消操作并强制其回滚?
解决方法:
HibernateSession提供了一个cancelQuery-Method,可用于取消当前查询.
注意:可能要花一些时间才能真正终止查询.
标签:jpa,hibernate,transactions,spring,java
来源: https://codeday.me/bug/20191029/1958084.html