从org.springframework.dao.DuplicateKeyException说起

Spring MyBatis的异常处理

我们可以获取状态码和SQL状态。 这样就知道了这个错误的具体含义,比如104:唯一约束验证失败。这就是我们故意设置的重复主键问题。

首先,定义一个异常类,我们就来自定义一下前面的-104错误,就是HSQL的重复键的问题:

之后我们重新新建一个sql-error-codes.xml代码,并将它放到类路径的根目录下,这样Spring会发现它并使用我们自定义的文件,在配置中定义如下:

之后就可以使用我们自己定义的异常类了。出现异常后,VehicleDuplicateKeyException就抛出了。 DataAccessException是RuntimeException,是无需检查的异常,不要求进行代码处理。

Spring的Dao抛上来的异常通常有:

CleanupFailureDataAccessException 一项操作成功地执行,但在释放数据库资源时发生异常(例如,关闭一个Connection)

DataAccessResourceFailureException 数据访问资源彻底失败,例如不能连接数据库

DataIntegrityViolationException Insert或Update数据时违反了完整性,例如违反了惟一性限制

DataRetrievalFailureException 某些数据不能被检测到,例如不能通过关键字找到一条记录

DeadlockLoserDataAccessException 当前的操作因为死锁而失败

IncorrectUpdateSemanticsDataAccessException Update时发生某些没有预料到的情况,例如更改超过预期的记录数。当这个异常被抛出时,执行着的事务不会被回滚

InvalidDataAccessApiusageException 一个数据访问的JAVA API没有正确使用,例如必须在执行前编译好的查询编译失败了

InvalidDataAccessResourceUsageException 错误使用数据访问资源,例如用错误的SQL语法访问关系型数据库

OptimisticLockingFailureException 乐观锁的失败。这将由ORM工具或用户的DAO实现抛出

TypemismatchDataAccessException Java类型和数据类型不匹配,例如试图把String类型插入到数据库的数值型字段中

UncategorizedDataAccessException 有错误发生,但无法归类到某一更为具体的异常中

这样服务层可以精确的捕获异常,或者向上继续抛出异常。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180609G1AFPS00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券