从源码解析 Spring 数据库异常抽理

本文解析了Spring操作数据库时如何处理异常,特别是通过SQLException的errorCode和SQLState进行异常转换。Spring的DataAccessException作为所有数据库异常的基类,允许在无需捕获的情况下处理异常。默认的SQLExceptionTranslator会根据errorCode进行转换,可通过自定义实现扩展转换逻辑。文章总结了Spring异常处理的优势和自定义异常转换的方法。
摘要由CSDN通过智能技术生成

初入学习 JDBC 操作数据库,想必大家都写过下面的代码:

数据库为:H2

JDBC 操作数据库

如果需要处理特定 SQL 异常,比如 SQL 语句错误,这个时候我们应该怎么办?

查看 SQLException 源码,我们可以发现两个重要的方法。

SQLException.getErrorCode:返回数据库特定的错误码,由数据库厂商制定,不同厂商错误码不同。如重复主键错误码在 MySQL 中是 1062,而在 Oracle 中却是 1。

SQLException.getSQLState:返回 XOPEN 或 SQL:2003 制定的错误码规范。数据库厂商会将不同错误消息映射成同一个错误码

所以我们可以根据 SQLException.getErrorCode 处理相应的数据库异常。

JDBC 异常处理

由于数据库厂商错误码不相同,这就导致如果我们更换数据库,上面判断逻辑就必须重写。

下面我们使用 Spring 操作数据库。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值