Транзакция не откатывается

Я использую 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);
    }

}

Теперь я могу сохранить / обновить, но Transaction не выполняет откат... как заставить их работать оба?

1 ответ

Возможно, вы столкнулись с тем, что автокоммит включен. Вам придется отключить это

<property name="hibernate.connection.autocommit">false</property> 

и явно сделайте коммит самостоятельно через session.getTransaction().commit, если все в порядке.

Другие вопросы по тегам