Spring Dao异常分类

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值