今天看了下Spring的源码——关于JDBC的"薄"封装,Spring 用一个Spring JDBC模板类来封装了繁琐的JDBC操作。下面仔细讲解一下Spring JDBC框架。

一、首先看一下为什么要对JDBC进行封装?

传统的JDBC API实现比较底层,不管用户执行一个复杂的数据库操作还是一个简单的数据库查询操作,都有一个模板可以使用:捕获或抛出异常—获取连接—创建Statement或PreparedStatement—执行数据库操作—获取结果(ResultSet)—其他操作—处理异常—关闭ResultSet—关闭Statement或PreparedStatement—关闭连接。这样的重复操作会让人比较有结构感的同时也消耗了大量的时间。既然所有的数据库操作都可以引用这一模板。那Spring就对JDBC API进行了一层"薄"封装,让程序员脱离繁琐的结构而只编写各个数据库操作程序中的核心部分:CRUD。通过在配置文件中配置数据源来获取连接。这样就减少了那些在传统JDBC编程中的重复编程,让这部分重复交由Spring JDBC容器来处理。

二、Spring JDBC封装是怎样的?

Spring JDBC是提供了一个数据库操作的模板类JdbcTemplate来进行封装的。org.springframework.jdbc.core.JdbcTemplate extends JdbcAccessor implements JdbcOperations 。下面我们来具体看一下这个封装类:

1、JdbcAccessor 是一个抽象类,实现了InitializingBean接口。InitializingBean接口实现了对BeanFactory中的所有属性设置后的响应。JdbcAccessor实现InitializingBean的唯一方法afterPropertiesSet来对设置数据源和其他的日志信息和异常信息和是否是LazyInit(懒加载)。

2、JdbcOperations是一个接口。这个接口定义了一个JDBC操作的集合,多数用回调来对操作进行定义。下面就是其中的方法定义,基本上也可以作为SpringJDBC的文档进行阅读。

操作 JdbcOperations 方法定义 
处理简单连接Connection Object execute(ConnectionCallback action)
处理静态查询Statement

Object execute(StatementCallback action)

void execute(String sql)

Object query(String sql, ResultSetExtractor rse)

void query(String sql, RowCallbackHandler rch)

List query(String sql, RowMapper rowMapper)

Object queryForObject(String sql, RowMapper rowMapper)

Object queryForObject(String sql, Class requiredType)

Map queryForMap(String sql)

long queryForLong(String sql)

int queryForInt(String sql)

List queryForList(String sql, Class elementType)

List queryForList(String sql)

SqlRowSet queryForRowSet(String sql)

int update(String sql)

int[] batchUpdate(String[] sql)

处理PreparedStatement

Object execute(PreparedStatementCreator psc, PreparedStatementCallback action)

Object execute(String sql, PreparedStatementCallback action)

Object query(PreparedStatementCreator psc, ResultSetExtractor rse)

Object query(String sql, PreparedStatementSetter pss, ResultSetExtractor rse)

Object query(String sql, Object[] args, int[] argTypes, ResultSetExtractor rse)

Object query(String sql, Object[] args, ResultSetExtractor rse)

void query(PreparedStatementCreator psc, RowCallbackHandler rch)

void query(String sql, PreparedStatementSetter pss, RowCallbackHandler rch)

void query(String sql, Object[] args, int[] argTypes, RowCallbackHandler rch)

void query(String sql, Object[] args, RowCallbackHandler rch)

List query(PreparedStatementCreator psc, RowMapper rowMapper)

List query(String sql, PreparedStatementSetter pss, RowMapper rowMapper)

List query(String sql, Object[] args, int[] argTypes, RowMapper rowMapper)

List query(String sql, Object[] args, RowMapper rowMapper)

Object queryForObject(String sql, Object[] args, int[] argTypes, RowMapper rowMapper)

Object queryForObject(String sql, Object[] args, RowMapper rowMapper)

Object queryForObject(String sql, Object[] args, int[] argTypes, Class requiredType)

Object queryForObject(String sql, Object[] args, Class requiredType)

Map queryForMap(String sql, Object[] args, int[] argTypes)

Map queryForMap(String sql, Object[] args)

long queryForLong(String sql, Object[] args, int[] argTypes)

long queryForLong(String sql, Object[] args)

int queryForInt(String sql, Object[] args, int[] argTypes)

int queryForInt(String sql, Object[] args)

List queryForList(String sql, Object[] args, int[] argTypes, Class elementType)

List queryForList(String sql, Object[] args, Class elementType)

List queryForList(String sql, Object[] args, int[] argTypes)

List queryForList(String sql, Object[] args)

SqlRowSet queryForRowSet(String sql, Object[] args, int[] argTypes)

SqlRowSet queryForRowSet(String sql, Object[] args)

int update(PreparedStatementCreator psc, KeyHolder generatedKeyHolder)

int update(String sql, PreparedStatementSetter pss)

int update(String sql, Object[] args, int[] argTypes)

int update(String sql, Object[] args)

int[] batchUpdate(String sql, BatchPreparedStatementSetter pss)

处理callable Statement

Object execute(CallableStatementCreator csc, CallableStatementCallback action)

Object execute(String callString, CallableStatementCallback action)

Map call(CallableStatementCreator csc, List declaredParameters)

上面的所有方法均throws DataAccessException;

3、DataAccessException继承NestedRuntimeException,NestedRuntimeException继承RuntimeException,主要输出异常信息。异常类都不会自己实现太多的方法而是一般调用父类方法来进行实现,只是更细化相应信息的输出和传入相应参数到父类方法进行执行。

4、大家可以看到上述方法很多是用回调来作为参数,而具体在JdbcTemplate中方法的实现还是利用传统的JDBC API中的Connection、Statement、PreparedStatement、ResultSet等类和相应的方法来进行实现回调。

org.springframework-jdbc的更多相关文章

  1. org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection 原因

    org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection 可能出现的原因     ...

  2. org.springframework.jdbc.BadSqlGrammarException

    org.springframework.jdbc.BadSqlGrammarException: ### Error querying database. Cause: java.sql.SQLExc ...

  3. org.springframework.jdbc.datasource

    org.springframework.jdbc.datasource.DataSourceUtils /** * Actually obtain a JDBC Connection from the ...

  4. HTTP Status 500 - Request processing failed; nested exception is org.springframework.jdbc.BadSqlGram

    HTTP Status 500 - Request processing failed; nested exception is org.springframework.jdbc.BadSqlGram ...

  5. 错误:org.springframework.jdbc.support.SQLErrorCodesFactory - SQLErrorCodes loaded

    使用spring+mybatis整合时报错:org.springframework.jdbc.support.SQLErrorCodesFactory - SQLErrorCodes loaded 错 ...

  6. jdbc连接oracle时报错 Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableC

    错误: Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; ...

  7. 使用Oracle数据库时的org.springframework.jdbc.BadSqlGrammarException:

    org.springframework.jdbc.BadSqlGrammarException: ### Error querying database. Cause: java.sql.SQLExc ...

  8. org.springframework.jdbc.UncategorizedSQLException

    org.springframework.jdbc.UncategorizedSQLException: StatementCallback; uncategorized SQLException fo ...

  9. org.springframework.jdbc.UncategorizedSQLException: Error attempting to get column 'alarmGroup' from result set. Cause: java.sql.SQLException: Error

    异常展示: org.springframework.jdbc.UncategorizedSQLException: Error attempting to get column 'alarmGroup ...

  10. 解决:No qualifying bean of type [org.springframework.jdbc.core.JdbcTemplate] found for dependency

    错误: Description: Field jdbcTemplate in com.gwd.dao.impl.IUserDaoImpl required a bean of type 'org.sp ...

随机推荐

  1. html 调用ActiveX

    html网页调用ActiveX控件时,要获取到ActiveX的ClassID,这个ClassID是注册到系统里的,而不是工程中的uuid,(下图为uuid). 正确的是在注册表的HKEY_CLASSE ...

  2. hibernate中的java对象有几种状态,其相互关系如何(区别和相互转换)。

    hibernate中的java对象有几种状态,其相互关系如何(区别和相互转换). 解答:在Hibernate中,对象有三种状态:临时状态.持久状态和游离状态. 临时状态:当new一个实体对象后,这个对 ...

  3. 简要描述如何结合struts、hibernate、spring开发Web应用?

    简要描述如何结合struts.hibernate.spring开发Web应用? 解答:Struts可以将jsp页面的表单关联起来,就是把JSP页面的表单数据封装成javaBean,这样的话,在acti ...

  4. 【BZOJ】3397: [Usaco2009 Feb]Surround the Islands 环岛篱笆(tarjan)

    http://www.lydsy.com/JudgeOnline/problem.php?id=3397 显然先tarjan缩点,然后从枚举每一个scc,然后向其它岛屿连费用最小的边,然后算最小的即可 ...

  5. Android中的Manifest.permission(应用权限)整理

    ACCESS_CHECKIN_PROPERTIES 允许读/写登记数据库(checkin database),中的“properties”表,用来改变他的值来上传东西. 这个权限第三方应用无法使用. ...

  6. node读写Excel操作

    目支持写Excel的node.js模块: node-xlsx: 基于Node.js解析excel文件数据及生成excel文件: excel-parser: 基于Node.js解析excel文件数据,支 ...

  7. HasMany() = (1..*) HasOptional() = (1..0,1) HasRequired() = (1..1)

    http://www.cnblogs.com/yeagen/archive/2012/10/15/2724237.html

  8. (转)使用 python Matplotlib 库绘图

    运行一个简单的程序例子: import matplotlib.pyplot as plt plt.plot([1,2,3]) plt.ylabel('some numbers') plt.show() ...

  9. Django Admin后台管理模块的使用

    Admin后台管理模块的使用 Django的管理员模块是Django的标准库django.contrib的一部分.这个包还包括其它一些实用的模块: django.contrib.auth django ...

  10. TypeScript 函数 (五)

    传递给一个函数的参数个数必须与函数期望的参数个数一致. 参数类别: 必须参数 可选参数 :可选参数必须在参数后面. 默认参数 :当用户没有传递这个参数或传递的值是undefined时. 它们叫做有默认 ...