jdbcTemplate使用方法实例解析

 更新时间:2020年02月12日 10:23:33   作者:小白coder  
这篇文章主要介绍了jdbcTemplate使用方法实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了jdbcTemplate使用方法实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

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

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

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

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

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

java文件:

@Autowired
  @Qualifier("dataSource")
  public DataSource dataSource;

  public JdbcTemplate getJdbcTemplate(){
    JdbcTemplate jdbcTemplate = new JdbcTemplate(this.dataSource);
    return jdbcTemplate;
  }

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

jdbcTemplate类型中有如下方法

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

execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;

update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;

query方法及queryForXXX方法:用于执行查询相关语句;

//1.查询一行数据并返回int型结果 
jdbcTemplate.queryForInt("select count(*) from test"); 
//2. 查询一行数据并将该行数据转换为Map返回 
jdbcTemplate.queryForMap("select * from test where name='name5'"); 
//3.查询一行任何类型的数据,最后一个参数指定返回结果类型 
jdbcTemplate.queryForObject("select count(*) from test", Integer.class); 
//4.查询一批数据,默认将每行数据转换为Map    
jdbcTemplate.queryForList("select * from test"); 
//5.只查询一列数据列表,列类型是String类型,列名字是name 
jdbcTemplate.queryForList(" 
select name from test where name=?", new Object[]{"name5"}, String.class); 
//6.查询一批数据,返回为SqlRowSet,类似于ResultSet,但不再绑定到连接上 
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框架来实现了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • MyBatis注解实现动态SQL问题

    MyBatis注解实现动态SQL问题

    这篇文章主要介绍了MyBatis注解实现动态SQL问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Vue3实现多页面跳转效果的几种方式

    Vue3实现多页面跳转效果的几种方式

    Vue.js是一个用于构建用户界面的渐进式 JavaScript 框架,它提供了多种方法来实现页面之间的导航,在 Vue 3 中,页面跳转主要通过 Vue Router 来管理,同时也支持其他方式如编程式导航和使用锚点链接,本文将详细介绍 Vue 3 中的各种页面跳转方式,需要的朋友可以参考下
    2025-03-03
  • 详解Spring依赖注入的三种方式以及优缺点

    详解Spring依赖注入的三种方式以及优缺点

    IoC 和 DI 是 Spring 中最重要的两个概念,其中 IoC(Inversion of Control)为控制反转的思想,而 DI(Dependency Injection)依赖注入为其(IoC)具体实现。那么 DI 实现依赖注入的方式有几种?这些注入方式又有什么不同?本文就来和大家一起详细聊聊
    2022-08-08
  • 详解5种Java中常见限流算法

    详解5种Java中常见限流算法

    在高并发系统中,出于系统保护角度考虑,通常会对流量进行限流;不但在工作中要频繁使用,而且也是面试中的高频考点。本文就为大家整理了5种Java中常见限流算法,需要的可以参考一下
    2023-04-04
  • Java并发中线程封闭知识点详解

    Java并发中线程封闭知识点详解

    在本篇文章里我们给大家整理了关于Java并发中线程封闭的知识点总结内容,需要的朋友们学习参考下。
    2019-07-07
  • 关于Springboot2.x集成lettuce连接redis集群报超时异常Command timed out after 6 second(s)

    关于Springboot2.x集成lettuce连接redis集群报超时异常Command timed out afte

    这篇文章主要介绍了Springboot2.x集成lettuce连接redis集群报超时异常Command timed out after 6 second(s),本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2021-03-03
  • 关于String.format()格式化输出方式

    关于String.format()格式化输出方式

    String.format()是Java的格式化输出方法,支持多种数据类型和格式化选项,它在格式化和拼接字符串时具有较高的灵活性,但效率相对较低,特别是在处理大量数据时,在实际编程中,应根据具体需求选择合适的字符串拼接方式
    2024-12-12
  • java设计模式笔记之代理模式

    java设计模式笔记之代理模式

    这篇文章主要为大家详细介绍了java设计模式之代理模式笔记,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10
  • java 直接调用python脚本,并传递参数代码实例

    java 直接调用python脚本,并传递参数代码实例

    这篇文章主要介绍了java调用python脚本传递参数的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • java实现多图片上传功能

    java实现多图片上传功能

    这篇文章主要为大家详细介绍了java多图片同步上传功能的实现方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08

最新评论