Spring Dao异常分类

来源:互联网 发布:linux 内核打印调用栈 编辑:程序博客网 时间:2024/05/29 09:23

  最近在处理消费kafka信息时遇到一个问题:如果读到了消息,指针也偏移了,但是往数据库写的时候,库挂了,那么这个消息的内容就丢失了。解决方案是:把消费的内容转成json或者xml放到一个文件里。但是kafka上面的数据有很多是我们不需要的,也就是这种数据出了异常(比如转json异常,某个必须字段为null等等)我们是不关注的,是不需要存到文件里的。那么问题来了:什么异常才是“数据库连不上”异常?
  Spring的DAO框架没有抛出与特定技术相关的异常,例如SQLException或HibernateException,抛出的异常都是与特定技术无关的org.springframework.dao.DataAccessException类的子类,避免系统与某种特殊的持久层实现耦合在一起。DataAccessException是RuntimeException,是一个无须检测的异常,不要求代码去处理这类异常,遵循了Spring的一般理念:异常检测会使代码到处是不相关的catch或throws语句,使代码杂乱无章;并且NestedRuntimeException的子类,是可以通过NestedRuntimeException的getCause()方法获得导致该异常的另一个异常。
  Spring的数据库相关异常分类有:

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

  如上表格:其中有一个异常叫“DataAccessResourceFailureException”:数据访问资源彻底失败,例如不能连接数据库。我故意把数据库连接密码写错,然后在操作数据那段代码旁catch了测试了一下(因为我没办法把库搞挂掉测试[捂脸]),得到的结果是:确实获取到一个异常叫“CannotGetJdbcConnectionException”,类名已经很清晰的表达了该异常的含义。查了一下spring源码,发现该类正是继承于DataAccessResourceFailureException。所以,捕获这个DataAccessResourceFailureException可以成功的过滤诸如:“必须字段为null”,“某个字段长度过长”等其他数据库异常,问题解决。
异常继承图  

0 0
原创粉丝点击