从源码解析 Spring JDBC 异常抽象

本文详细解析了Spring操作数据库时如何处理JDBC异常,包括Spring如何将SQL异常转换为内部异常,如BadSqlGrammarException,并介绍了实现细节,如SQLExceptionTranslator的工作原理,以及提供了自定义异常转换的三种方法。通过这些机制,Spring有效地屏蔽了不同数据库错误码不一致的问题。
摘要由CSDN通过智能技术生成

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

数据库为:H2

JDBC 操作数据库

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

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

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

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

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

JDBC 异常处理

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值