JDBC高级部分

简介:

1、    数据源和连接池

lDataSource用来取代DriverManager来获取Connection

l通过DataSource获得Connection速度很快;

l通过DataSource获得的Connection都是已经被包裹过的(不是驱动原来的连接),他的close方法已经被修改。

l一般DataSource内部会用一个连接池来缓存Connection,这样可以大幅度提高数据库的访问速度;

l连接池可以理解成一个能够存放ConnectionCollection

l我们的程序只和DataSource打交道,不会直接访问连接池;

 

2、   一个简单的数据源实现

l  使用代理模式的Connection(核心代码)

        class MyConnection implements Connection{

                 private Connection realConn;

                 private LinkedList connPool;

                 MyConnection(Connection rConn, LinkedList cPool){

                           this.realConn=rConn;

                           this.connPool=cPool;

                 }

                 public void close(){

                           this.connPool.addLast(this);

                 }

                 //….

        }

l  DataSource(核心代码)

         class MyDataSource implements DataSource{

                   private LinkedList connPool = new Vector();

                   public Connection getConneciton (){

                            if(this.connPool.size()>0)

                                      return this.connPool.removeFirst(0);

                            return createConnection();

                   }

                   private Connection createConnection(){

                     Connection realConn = DriverManager.getConnection();

                     Connection myConn =

                            new MyConnection(realConn,this.connPool);

                     return myConn;

                   }

                   //….

         }

3、   常用的开源实现DBCP

l  使用DBCP必须用的三个包:

         commons-dbcp-1.2.1.jar, commons-pool-1.2.jar, commons-collections-3.1.jar

l  配置参数。

l  Java API: BasicDataSourceFactory.createDataSource(

properties);

 

4、   使用继承优化JDBC代码(模板模式)

l  优化查询操作,区分开变化和不变的部分:

         sql ResultSet 的处理是变化部分,创建和释放资源部分是不变部分。

l  提取超类,将不变部分放入超类,变化部分留给子类实现。

l  超类的主要代码:

         public Object find(String sql, Object[] args) {

           …

           rs = ps.executeQuery();

           if (rs.next()) return rowMapper(rs);

           …

         }

         protected abstract Object rowMapper(ResultSet rs);

5、   使用组合优化JDBC代码(策略模式)

l  优化查询操作,区分开变化和不变的部分:

         sql ResultSet 的处理是变化部分,创建和释放资源部分是不变部分。

l  提取接口封装变化部分。

l  JDBC操作主要代码:

         public Object find(String sql, Object[] args, RowMapper rowMapper) {

                   …

                   rs = ps.executeQuery();

                   if (rs.next())return rowMapper.mapRow(rs);

                   …

         }

l  回调接口:

         public interface RowMapper {

                   public Object mapRow(ResultSet rs) throws SQLException;

         }

 

6、   SpringJdbcTemplate

l  查询带有参数,和行映射方法:

         public Object queryForObject(String sql, Object[] args, RowMapper rowMapper), 使用自定义的 UserRowMapper 完成映射。

l  一个RowMapper的常用实现BeanPropertyRowMapper,该实现可将结果集转换成一个Java Bean(字段名与Java Bean属性名不符合规范,可用别名处理)

l  public List query(String sql, Object[] args, RowMapper rowMapper)返回多个结果。

l  public int queryForInt(String sql)(:select count(*) from user),其他结果比如String可用queryForObject方法向下转型。

l  public Map queryForMap(String sql, Object[] args)返回若类型的Mapkey:字段名或别名,value:列值)。

l  public List queryForList(String sql, Object[] args)返回多Map

l  更新public int update(String sql, Object[] args)

l  插入数据并获得结果:

         public Object execute(ConnectionCallback action)

l  其他方法简介

 

7、   SpringNamedParameterJdbcTemplate

l  NamedParameterJdbcTemplate内部包含了一个JdbcTemplate,所以JdbcTemplate能做的事情NamedParameterJdbcTemplate都能干; NamedParameterJdbcTemplate相对于JdbcTemplate主要增加了参数可以命名的功能。

l  public Object queryForObject(String sql, Map paramMap, RowMapper rowMapper)

l  public Object queryForObject(String sql, SqlParameterSource paramSource, RowMapper rowMapper)

         SqlParameterSource 的两个主要实现 MapSqlParameterSource

          BeanPropertySqlParameterSource

l  public int update(String sql, SqlParameterSource paramSource, KeyHolder generatedKeyHolder)保存数据获得主键。

 

8、   SpringSimpleJdbcTemplate

l  SimpleJdbcTemplate内部包含了一个NamedParameterJdbcTemplate;所以NamedParameterJdbcTemplate能做的事情SimpleJdbcTemplate都能干,SimpleJdbcTemplate相对于NamedParameterJdbcTemplate主要增加了JDK5.0的泛型和可变长度参数支持。

l  public <T> List<T> query(String sql, ParameterizedRowMapper<T> rm, Object... args)

l  public <T> T queryForObject(String sql, ParameterizedRowMapper<T> rm, SqlParameterSource args)

l  public <T> List<T> query(String sql, ParameterizedRowMapper<T> rm, SqlParameterSource args)

l  getJdbcOperations返回的是JdbcOperations(实现JdbcTemplate)

l  getNamedParameterJdbcOperations返回的是NamedParameterJdbcOperations(实现是NamedParameterJdbcTemplate)

 

9、   实现UserDao接口

l  实现UserDao接口

l  修改daoconfig.properties文件,切换UserDao的实现。

l  测试UserDao的新的实现类。

 


本文转自 tianya23 51CTO博客,原文链接:http://blog.51cto.com/tianya23/270849,如需转载请自行联系原作者

相关文章
|
3天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
269 116
|
18天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
12天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
661 220
|
5天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
334 34
Meta SAM3开源:让图像分割,听懂你的话
|
10天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1534 157
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
897 61
|
7天前
|
编解码 Linux 数据安全/隐私保护
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
293 140