spring3+hibernate4 问题之事物异常(一)

public void add(UserEntity userEntity) throws RuntimeException {
        Session session = sessionFactory.getCurrentSession();
        logger.info("add: userId=" + userEntity.getUserId());
        try {
            session.save(userEntity);
        } catch (RuntimeException e) {
            // 这里catch不到
        }
    }
 

严重: Exception occurred during processing request: Duplicate entry '2' for key 'PRIMARY'; SQL [n/a]; constraint [null]; nested exception is org.hibernate.exception.ConstraintViolationException: Duplicate entry '2' for key 'PRIMARY'

 

 

先看这段代码,咋一看catch是可以捕获到,ConstraintViolationException异常是runtime的子类,但是搞清楚,在hibernate4中,我们不在使用hibernateTemplate,也就是说,如果配置了@transcanl,spring仅仅帮你openSession和tx.commit 操作。但是上面的异常是commit的时候发生的,你save的时候根本没有异常,而你的service层和dao层都是spring帮你代理事物的,所以这个异常只有在action层可以捕获到,总而最终传送给错误页。

你可能感兴趣的:(java,spring,Hibernate,idea)