Spring学习系列之JdbcTemplate

本文探讨了为何引入JdbcTemplate,以解决代码重复性和异常体系问题。解释了JdbcOperations接口、JdbcAccessor抽象类以及核心类JdbcTemplate的职责。JdbcTemplate采用模板方法设计模式,配合回调方法操作数据库。此外,文章还介绍了异常转换机制,包括SQLExceptionSubclassTranslator、SQLStateSQLExceptionTranslator和SQLErrorCodeSQLExceptionTranslator三个子类,它们用于统一处理不同数据库供应商的异常。
摘要由CSDN通过智能技术生成

0x01 为什么会有JdbcTemplate

原因一:代码重复性

JDBC编程需要我们获取数据库连接,然后进行增删改查,最后关闭一些资源,然后还要捕获异常。那么这些代码都是重复的,我们可以通过模板方法模式去简化这些代码

原因二:异常体系

根据JDBC规范,不同实现厂商会抛出SQLException异常,这个异常通过ErrorCode来区分不同错误,但是不同厂商针对同一个错误提供的ErrorCode可能不同,那么需要我们统一处理这些差异

JdbcTemplate就解决了上述两个问题。

0x02 相关类讲解

JdbcTemplate继承了JdbcAccessor类,并实现了JdbcOprations接口。

JdbcOprations

该接口提供了所有JDBC相关需要实现的方法

JdbcAccessor

该类是一个抽象类。

实现了Spring的InitializingBean接口,在afterPropertiesSet方法中,根据lazyInit属性加载异常转换器(就是将不同ErrorCodeSQLException封装成Spring的DataAccessException),调用的方法是getExceptionTranslator方法

public synchronized SQLExceptionTranslator getExceptionTranslator() {
   
		if (this.exceptionTranslator == null) {
   
			DataSource dataSource = getDataSource();
			if (dataSource != null) {
   
				this.exceptionTranslator = new SQLErrorCodeSQLExceptionTranslator(dataSource);
			}
			else {
   
				this.exceptionTranslator = new SQLStateSQLExceptionTranslator();
			}
		}
		return this.exceptionTranslator;
	}

DataSource是在JDBC2.0之后引入的,代替了DriverManager的数据库连接创建方式

JdbcTemplate

该类采用了模板方法模式,同时配合回调方法

// 该方法会被其他方法调用
// 比如query方法,query方法中会有实现StatementCallback接口的一个query内部类
@Override
public <T> T execute(StatementCallback<T> action) throws DataAccessException {
   
	Assert.notNull(action, "Callback object must not be null");
	// 此处通过该工具类获取Connection会被绑定在当前线程中,以便Spring的统一事务使用
	Connection con = DataSourceUtils.getConnection(getDataSource(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值