zoukankan      html  css  js  c++  java
  • jdbcTemplate的简单介绍

        Spring JDBC抽象框架core包提供了JDBC模板类,其中JdbcTemplate是core包的核心类,所以其他模板类都是基于它封装完成的,JDBC模板类是第一种工作模式。

    JdbcTemplate类通过模板设计模式帮助我们消除了冗长的代码,只做需要做的事情(即可变部分),并且帮我们做哪些固定部分,如连接的创建及关闭。

    在application-mybatis.xml中配置的DataSource注入到JdbcTemplate中,就可以使用JdbcTemplate模板了

    配置文件中加入以下内容:

    1 <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
    2         <property name="driverClassName" value="${jdbc.driverClassName}"/><!--加载驱动-->
    3         <property name="url" value="${jdbc.url}"/><!--数据库的位置-->
    4         <property name="username" value="${jdbc.username}"/><!--数据库的用户名-->
    5         <property name="password" value="${jdbc.password}"/><!--对应的密码-->
    6         <property name="maxActive" value="50"/><!--连接池的最大活动数-->
    7         <property name="minIdle" value="5"/><!--最少保持5条空闲连接-->
    8         <property name="maxWait" value="5000"/><!--等待时间5秒-->
    9 </bean>

    java文件:

    1     @Autowired
    2     @Qualifier("dataSource")
    3     public DataSource dataSource;
    4 
    5     public JdbcTemplate getJdbcTemplate(){
    6         JdbcTemplate jdbcTemplate = new JdbcTemplate(this.dataSource);
    7         return jdbcTemplate;
    8     }

    此时jdbcTemplate变量中便会有相关的数据库的基本参数配置信息,

    还有其他方式加载配置信息,可参考https://www.cnblogs.com/wang3680/p/c665e246108c1c9abd637868852d9a77.html,https://jinnianshilongnian.iteye.com/blog/1423897中。

    jdbcTemplate类型中有如下方法

      JdbcTemplate主要提供以下五类方法:

    • execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;
    • update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;
    • query方法及queryForXXX方法:用于执行查询相关语句;
    •  1 //1.查询一行数据并返回int型结果  
       2 jdbcTemplate.queryForInt("select count(*) from test");  
       3 //2. 查询一行数据并将该行数据转换为Map返回  
       4 jdbcTemplate.queryForMap("select * from test where name='name5'");  
       5 //3.查询一行任何类型的数据,最后一个参数指定返回结果类型  
       6 jdbcTemplate.queryForObject("select count(*) from test", Integer.class);  
       7 //4.查询一批数据,默认将每行数据转换为Map       
       8 jdbcTemplate.queryForList("select * from test");  
       9 //5.只查询一列数据列表,列类型是String类型,列名字是name  
      10 jdbcTemplate.queryForList("  
      11 select name from test where name=?", new Object[]{"name5"}, String.class);  
      12 //6.查询一批数据,返回为SqlRowSet,类似于ResultSet,但不再绑定到连接上  
      13 SqlRowSet rs = jdbcTemplate.queryForRowSet("select * from test");  
    • call方法:用于执行存储过程、函数相关语句。

    支持的回调接口如下:

    JdbcTemplate类支持的回调类:

    • 预编译语句及存储过程创建回调:用于根据JdbcTemplate提供的连接创建相应的语句;

             PreparedStatementCreator:通过回调获取JdbcTemplate提供的Connection,由用户使用该Conncetion创建相关的PreparedStatement;

             CallableStatementCreator:通过回调获取JdbcTemplate提供的Connection,由用户使用该Conncetion创建相关的CallableStatement;

    • 预编译语句设值回调:用于给预编译语句相应参数设值;

             PreparedStatementSetter通过回调获取JdbcTemplate提供的PreparedStatement,由用户来对相应的预编译语句相应参数设值;

             BatchPreparedStatementSetter:;类似于PreparedStatementSetter,但用于批处理,需要指定批处理大小;

    • 自定义功能回调:提供给用户一个扩展点,用户可以在指定类型的扩展点执行任何数量需要的操作;

             ConnectionCallback通过回调获取JdbcTemplate提供的Connection,用户可在该Connection执行任何数量的操作;

             StatementCallback通过回调获取JdbcTemplate提供的Statement,用户可以在该Statement执行任何数量的操作;

             PreparedStatementCallback通过回调获取JdbcTemplate提供的PreparedStatement,用户可以在该PreparedStatement执行任何数量的操作;

             CallableStatementCallback通过回调获取JdbcTemplate提供的CallableStatement,用户可以在该CallableStatement执行任何数量的操作;

    • 结果集处理回调:通过回调处理ResultSet或将ResultSet转换为需要的形式;

             RowMapper用于将结果集每行数据转换为需要的类型,用户需实现方法mapRow(ResultSet rs, int rowNum)来完成将每行数据转换为相应的类型。

             RowCallbackHandler用于处理ResultSet的每一行结果,用户需实现方法processRow(ResultSet rs)来完成处理,在该回调方法中无需执行rs.next(),该操作由JdbcTemplate来执行,用户只需按行获取数据然后处理即可。

             ResultSetExtractor用于结果集数据提取,用户需实现方法extractData(ResultSet rs)来处理结果集,用户必须处理整个结果集;

    JdbcTemplate执行流程:首先定义SQL,其次调用JdbcTemplate方法执行SQL,最后通过RowCallbackHandler回调处理ResultSet结果集。

    Spring JDBC解决方法相比传统JDBC编程方式简单多了,只有可变部分需要我们来做,其他的都由Spring JDBC框架来实现了。

  • 相关阅读:
    Tensorflow 学习
    几种常见损失函数
    两人比赛先选后选谁获胜系列的动态规划问题
    LeetCode 全解(bug free 训练)
    局部敏感哈希LSH
    Annoy解析
    MCMC例子
    TinyBERT简单note
    ALBERT简单note
    求根号2, 网易的一道面试题
  • 原文地址:https://www.cnblogs.com/alice-cj/p/10483660.html
Copyright © 2011-2022 走看看