您的位置:首页 > 其它

看看牛人如何Handle Exception

2008-09-04 15:57 211 查看
以下为全文拷贝:来自http://trace.javaeye.com/blog

MyEclipse有一个Hibernate的插件,用它可以快速地生成与Hibernate操作有关的代码,十分方便。初学Hibernate时,调用着这些自动生成的代码,看着数据库中一行行操作成功的数据,喜悦之情溢于言表。

但是,今天,当我将hibernate用于项目,在Servlet环境下调用时,我需要的ServletExcpetion竟然无从产生。难道当数据库操作失败时,Servlet容器就放过这个错吗?显然不能。然而看看自己的代码,我找不到一处强制抛出错误的地方(Eclipse会在强制处理Exception的地方提示你)。再看看Hibernate自动生成的DAO类,果然没有一个方法抛出异常:

public void save(Employee transientInstance) {

log.debug("saving Employee instance");

try {

getSession().save(transientInstance);

log.debug("save successful");

} catch (RuntimeException re) {

log.error("save failed", re);

throw re;

}

}

public void delete(Employee persistentInstance) {

log.debug("deleting Employee instance");

try {

getSession().delete(persistentInstance);

log.debug("delete successful");

} catch (RuntimeException re) {

log.error("delete failed", re);

throw re;

}

}

public Employee findById(java.lang.String id) {

log.debug("getting Employee instance with id: " + id);

try {

Employee instance = (Employee) getSession().get(

"apqp.hbm.admin.employee.Employee", id);

return instance;

} catch (RuntimeException re) {

log.error("get failed", re);

throw re;

}

}

这些方法在内部处理的是RuntimeException。可是save()等一些数据库操作方法应该是会抛出异常的啊,按照Hibernate API,这些方法都会抛出HibernateException。但是(看看,多曲折啊),当我在API中将HibernateException找到时,发现它竟然是RuntimeException的子类,难怪抓不住它的!

现在我搞清楚了,操作hibernate时,该抛出异常的地方你得自己抓异常,比如:

DepartmentDAO dao = new DepartmentDAO();

Transaction t = dao.getSession().beginTransaction();

dao.save(new Department("采购部"));

t.commit();

dao.getSession().close();

这里不写异常也能运行,但是不符合业务逻辑的需要。因此,在可能出现异常的地方,要catch HibernateExcpetion。可是,那些地方时可能出现异常的地方呢?参照了一些高手的代码,综合了一下他们的特点,我决定:

DepartmentDAO dao = new DepartmentDAO();

Transaction t = null;

try {

t = dao.getSession().beginTransaction();

dao.save(new Department("采供部"));

t.commit();

dao.getSession().close();

} catch (HibernateException e) {

// Do Some Exception Handler Operate

if (t!=null) {

t.rollback();

}

} finally {

dao.getSession().close();

}

这样,我就抓到HibernateExcpetion了。
补充:一直对如何Handle Exception有疑惑,除了使用System.err.println()和e.printStackTrace()将Exception报告出来、使用throw讲Exception继续抛出、使用try-catch实现类似if-else的转向功能、使用try-catch给同一变量赋不同的value值(eg: try{i=0}catch(){i=1}),还没遇到过其他Handle Exception的方法。上面载录过来的帖子开阔了我的视野,尤其是使用try-catch进行log处理和回滚。学习!!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: