spring ibatis 异常

Spring3 Mybatis 异常处理

通常在 Dao 层将所有异常都转嫁到 Spring 的 RuntimeException 体系中来 -DataAccessException

 Spring的DAO框架没有抛出与特定技术相关的异常,例如SQLException或HibernateException,抛出的异常都是与特定技术无关的org.springframework.dao.DataAccessException类的子类,避免系统与某种特殊的持久层实现耦合在一起。DataAccessException是RuntimeException,是一个无须检测的异常,不要求代码去处理这类异常,遵循了Spring的一般理念:异常检测会使代码到处是不相关的catch或throws语句,使代码杂乱无章;并且NestedRuntimeException的子类,是可以通过NestedRuntimeException的getCause()方法获得导致该异常的另一个异常。Spring的异常分类有

Spring的DAO异常层次

异常

何时抛出

CleanupFailureDataAccessException一项操作成功地执行,但在释放数据库资源时发生异常(例如,关闭一个Connection)
DataAccessResourceFailureException数据访问资源彻底失败,例如不能连接数据库
DataIntegrityViolationExceptionInsert或Update数据时违反了完整性,例如违反了惟一性限制
DataRetrievalFailureException某些数据不能被检测到,例如不能通过关键字找到一条记录
DeadlockLoserDataAccessException当前的操作因为死锁而失败
IncorrectUpdateSemanticsDataAccessExceptionUpdate时发生某些没有预料到的情况,例如更改超过预期的记录数。当这个异常被抛出时,执行着的事务不会被回滚
InvalidDataAccessApiusageException一个数据访问的JAVA API没有正确使用,例如必须在执行前编译好的查询编译失败了
invalidDataAccessResourceUsageException错误使用数据访问资源,例如用错误的SQL语法访问关系型数据库
OptimisticLockingFailureException乐观锁的失败。这将由ORM工具或用户的DAO实现抛出
TypemismatchDataAccessExceptionJava类型和数据类型不匹配,例如试图把String类型插入到数据库的数值型字段中
UncategorizedDataAccessException有错误发生,但无法归类到某一更为具体的异常中

Spring的DAO异常层次是如此的细致缜密,服务对象能够精确地选择需要捕获哪些异常,捕获的异常对用户更有用的信息,哪些异常可以让她继续在调用堆栈中向上传递。

 

于是,我们在dao中只需要抛出这个运行时异常,我们就可以在

[java]  view plain copy
 
  1. /** 
  2.      *  根据时间获取日KPI数据 
  3.      * @param date 日期 
  4.      * @return 
  5.      */  
  6.     public List<KPIDataBean> getKPIOfDayDataByDate(String date) throws DataAccessException;  


并在它的实现类中也抛出这么个异常。

这样,在调用这个方法的时候,我们捕获这个异常即可:

[java]  view plain copy
 
  1. try {  
  2.     list = kpiDao.getKPIOfDayDataByDate(date);  
  3. catch(DataAccessException e) {  
  4.     System.out.println("test:" + e.getMessage());  
  5. }  


这样就可以捕获相应的异常了。

这是打印出来的信息

 test:nested exception is org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Communications link failure

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值