©
本文档使用 PHP中文网手册 发布
Spring提供了一种方便的方法,把特定于某种技术的异常,如SQLException
,
转化为自己的异常,这种异常属于以DataAccessException
为根的异常层次。这些异常封装了原始异常对象,这样就不会有丢失任何错误信息的风险。
除了对JDBC异常的封装,Spring也对Hibernate异常进行了封装,把它们从一种专有的checked异常 (Hibernate3.0以前的版本),转化为一系列抽象的运行时异常。对JDO也是这样。 它可以让你轻松处理大多数持久化异常(这些异常大多是不可恢复的,而且只出现在特定 的层次),而不再需要在DAO中编写讨厌的样板式的catch/throw代码块和异常声明。你仍然可以在需要 的地方捕获并处理这些异常。就像我们上面提到的,JDBC异常(包括特定于某种数据库 方言的异常)也可以被转化为同样的异常层次,这意味着你可以在一致的编程模型下,通 过JDBC来执行某些操作。
上述情况适用于Spring支持的各种ORM框架的模板类。如果使用基于拦截器的类,你在应用中
就得自己小心处理HibernateException
、
JDOException
等,最好是委托给
SessionFactoryUtils
的
convertHibernateAccessException
、
convertJdoAccessException
等方法。这些方法可以把相应的异常转
化为与org.springframework.dao
中定义的异常层次相兼容的异常。
其中JDOException
属unchecked异常,它们也可以被简单地抛出,
但这样做在异常处理方面牺牲了通用的DAO抽象。
下图展示了Spring提供的异常层次。
(注意图上所包含的异常类只是整个庞大的DataAccessException
异常层次中的一部分。)