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层可以捕获到,总而最终传送给错误页。