我在我的应用程序中使用OpenSessionInView。 我的目标是在发生任何异常时,在一个方法中回滚数据库中的所有更改。这是我的控制器:
@RequestMapping(value="/kartazadan.do", method=RequestMethod.GET )
@Transactional(rollbackFor=Exception.class)
public ModelAndView viewGET(HttpServletRequest request,
HttpServletResponse response) throws Exception{
int id = Integer.parseInt(ServletRequestUtils.getRequiredStringParameter(request, "id"));
ModelMap modelMap = new ModelMap();
KartaZadan kartaZadan = kartaZadanDAO.getkartaZadanById(id);
kartaZadan.setZadanie("TEST10");
kartaZadanDAO.update(kartaZadan);
kartaZadan = kartaZadanDAO.getkartaZadanById(null); //here when Exception should occurr and make transaction rollback
kartaZadanDAO.update(kartaZadan);
modelMap.addAttribute("kartaZadan", kartaZadan);
setCommonFields(modelMap);
modelMap.addAttribute("errorsEnabled", false);
return new ModelAndView("kartaZadan", modelMap);
}
使用下面给出的配置它可以工作: 在web.xml中:
<filter>
<filter-name>hibernateFilter</filter-name>
<filter-class>
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
</filter-class>
</filter>
<bean class="org.springframework.orm.hibernate3.support.OpenSessionInViewInterceptor">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
但是在这个策略中,我无法保存/更新视图中的任何行。所以我像这样烦恼了OpenSessionInViewFilter:
public class CustomOpenSessionInViewFilter extends OpenSessionInViewFilter{
@Override
public void closeSession(Session session, SessionFactory sessionFactory){
session.flush();
super.closeSession(session,sessionFactory);
}
}
现在我可以保存/更新,但是事务不会回滚...如何让它们同时工作?
答案 0 :(得分:0)
您所面对的可能是因为autoCommit已开启。你必须关闭它
<property name="hibernate.connection.autocommit">false</property>
并通过session.getTransaction()显式自己提交。如果一切正常,则提交。