`
xiaoZ5919
  • 浏览: 406775 次
  • 性别: Icon_minigender_1
  • 来自: 安平人@北京
博客专栏
Group-logo
Netty学习笔记
浏览量:73384
社区版块
存档分类
最新评论

JdbcTemplate的callback

阅读更多

    JdbcTemplate的CallBack回调机制很巧妙,算是aop的一种实现吧

    使用JdbcTemplate省掉了我们打开和关闭connection的操作,同时需要一提的是在CallBack接口实现类的Connection处于auto-commit状态,在CallBack的实现方法不能进行事物管理。

    execute代码

    

public Object execute(ConnectionCallback action) throws DataAccessException {
		Assert.notNull(action, "Callback object must not be null");

		Connection con = DataSourceUtils.getConnection(getDataSource());
		try {
			Connection conToUse = con;
			if (this.nativeJdbcExtractor != null) {
				// Extract native JDBC Connection, castable to OracleConnection or the like.
				conToUse = this.nativeJdbcExtractor.getNativeConnection(con);
			}
			else {
				// Create close-suppressing Connection proxy, also preparing returned Statements.
				conToUse = createConnectionProxy(con);
			}
			return action.doInConnection(conToUse);
		}
		catch (SQLException ex) {
			// Release Connection early, to avoid potential connection pool deadlock
			// in the case when the exception translator hasn't been initialized yet.
			DataSourceUtils.releaseConnection(con, getDataSource());
			con = null;
			throw getExceptionTranslator().translate("ConnectionCallback", getSql(action), ex);
		}
		finally {
			DataSourceUtils.releaseConnection(con, getDataSource());
		}
	}

        CallBack是一个接口,其中定义了doInConnection(conn),把要写的逻辑写在此方法中。

我们只需要传入一个conn即可,创建conn是前处理,关闭conn是后处理。 免去了这些繁琐的操作。JdbcTemplate的其它方法也是利用CallBack实现的

分享到:
评论

相关推荐

    spring自带的jdbcTemplate查询、插入预编译使用

    除了基本的查询和更新,`jdbcTemplate`还支持回调(Callback)机制,允许我们在执行数据库操作的过程中进行额外的处理。例如,我们可以使用`SimpleJdbcCall`来执行存储过程,并提供一个`SqlParameterSource`来传递...

    Spring JdbcTemplate api

    在`JdbcTemplate`的设计中,模板(Template)承担着事物控制、资源管理和异常处理的责任,而回调(Callback)则专注于实现应用程序特有的逻辑,如创建SQL语句、设置参数和处理结果集。这种分离使得开发者能够更专注...

    JdbcTemplate教程

    JdbcTemplate将我们使用的JDBC的流程封装起来,包括了异常的捕捉、SQL的执行、查询结果的转换等等。spring大量使用Template Method模式来封装固定流程的动作,XXXTemplate等类别都是基于这种方式的实现。 除了大量...

    59丨模板模式(下):模板模式与Callback回调函数有何区别和联系?1

    `JdbcTemplate`执行SQL查询时,会调用用户提供的回调方法来处理结果集,这类似于同步回调,因为结果处理在查询完成后立即进行,与模板模式的应用场景相似。 总的来说,回调函数和模板模式都是为了实现代码的复用和...

    Spring源代码解析(三):Spring_JDBC.doc

    这些方法通常会接受一个回调函数,即Callback接口的实现。用户在回调接口的实现中编写与数据库交互的具体逻辑,例如指定SQL语句。例如,以下代码展示了如何使用JdbcTemplate执行一个自定义的操作: ```java ...

    Spring源代码解析3:SpringJDBC[归纳].pdf

    `JdbcTemplate`遵循模板方法设计模式,通过回调函数(Callback)机制,允许用户在特定的接口中实现自定义的行为。例如,`JdbcTemplate`提供了一个`ConnectionCallback`接口,用户可以实现这个接口的`doInConnection...

    Spring的DAO

    Spring的DAO设计模式主要体现在模板(Template)和回调(Callback)两个概念上。 模板类,如`JdbcTemplate`,负责处理数据访问流程中的通用部分,包括事务管理、资源的打开和关闭,以及异常的处理。这些模板类通常...

    多步提交示例中各个类的调用顺序,包含源码及配置文件

    4. **Callback/Listener机制**:为了确保每一步的正确执行,可能会使用回调或监听器机制。例如,`AfterCompletionCallback`可以在事务完成后执行某些清理或通知任务。这些回调类会在适当的时间点被事务管理器调用。 ...

Global site tag (gtag.js) - Google Analytics