JdbcTemplate简介

  Java语言提供了jdbc来访问数据库,在jdbc api中需要手动的获取和释放连接等资源,使用起来需要做许多重复的工作。Spring在jdbc api的基础上做了抽象和深层次的封装,提供了JdbcTemplate来访问数据库。JdbcTemplate只是对jdbc api进行了抽象封装,并没有提供新的功能。

JdbcTemplate使用需要的依赖包

       <dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.1.9.RELEASE</version>
</dependency> <!--spring-core相关的依赖包-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.1.9.RELEASE</version>
</dependency> <!--spring-beans依赖包-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>5.1.9.RELEASE</version>
</dependency> <!--spring-expression依赖包-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<!--数据库相关的jdbc包-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.40</version>
</dependency>

JdbcTemplate主要提供了4种方法

  1.   execute:执行数据库的ddl语句。
  2.   update和batchUpdate:update方法用于执行增、删、改,batchUpdate方法用于执行批处理。
  3.    query和queryForXxx:改方法用于执行查询语句。

  call:用于执行存储过程,这篇博客不讲解这部分。

JdbcTemplate的使用讲解

  使用JdbcTemplate需要配置数据源以及将在Spring容器中注入JdbcTemplate的Bean。在applicationContext中配置如下

    <!--配置数据源:驱动类、url数据库用户名和密码-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="username" value="root" />
<property name="password" value="root" />
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<!--配置数据连接并设置是否使用unicode编码和编码格式为utf-8-->
<property name="url" value="jdbc:mysql://localhost:3306/spring-demo?useUnicode=true&amp;characterEncoding=utf-8" />
</bean> <!--将jdbctemplate注册到spring容器中,需要配置数据源-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource" />
</bean>

  测试需要用到junit和spring与junit集成的包,依赖如下

        <!--测试的依赖包-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<!--spring测试的依赖包-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>

JdbcTemplate的测试代码

1. execute方法:执行ddl语句

    @Test
public void testExecute() {
//测试JdbcTemplate的execute方法,该方法用于执行数据库的ddl语句。
String sql = "create table user1(id int not null auto_increment, name varchar(20), primary key(id))ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT '用户表1,测试ddl语句的执行'";
jdbcTemplate.execute(sql);
}

2. update方法:执行增、删、改

  jdbcTemplate对update方法进行了重载,方法分别是

  •   update(String sql, Object[] args);第二个参数是Object类型的数组。
  •   update(String sql, Object... args);第二个参数是可变参数。

  执行新增语句

    @Test
public void testInsert() {
//测试插入语句
String sql = "insert into student(id, name, sex) values(?, ?, ?)";
jdbcTemplate.update(sql, 1001, "刘备", "男");
}

  执行更新语句

    @Test
public void testUpdate() {
//根据id更新
String sql = "update student set name = ?, sex = ?, born = ? where id = ?";
Object[] student = new Object[]{"刘备", "男", "2000-05-03", 1001};
jdbcTemplate.update(sql, student);
}

  执行删除语句

    @Test
public void testDelete() {
//根据id删除数据
String sql = "delete from student where id = ?";
jdbcTemplate.update(sql, 1006);
}

3. batchUpdate:执行批量处理

  batchUpdate也有两个常用的重载方法:

  •   batchUpdate(String[] sqls):参数是更新语句的数组,不能使用站位符。
    @Test
public void testBatchUpdate() {
//批量执行更新表的语句,不能使用占位符。
String[] sqls = {"insert into student(name, sex, born) values('甘夫人','女','2000-10-03')",
"update student set name = '孙尚香' where id = 1006",};
jdbcTemplate.batchUpdate(sqls);
}
  •   batchUpdate(String sql, List<Object[]> args):第二个参数是Object数组的列表。
    @Test
public void testBatchInsert() {
//批量执行插入语句,JdbcTemplate的参数为List<Object[]>类型。
String sql = "insert into student(id, name, sex, born) values(?, ?, ?, ?)";
List<Object[]> parameterList = new ArrayList<>();
parameterList.add(new Object[]{1004, "甘夫人", "女", "2000-08-03"});
parameterList.add(new Object[]{1005, "麋夫人", "女", "2000-09-03"});
jdbcTemplate.batchUpdate(sql, parameterList);
}

4. queryForObject:查询单个对象

  常用的重载方法如下:

  •   queryForObject(String sql, Class<T> requiredType, Object... args):该方法返回requiredType指定类型的返回值, 第三个参数为可变参数。
  •   queryForObject(String sql, Object[] args, Class<T> requiredType):该方法返回requiredType指定类型的返回值,第二个参数为占位符需要传的参数。
    @Test
public void testCount() {
//测试查询返回一个参数
String sql = "select count(*) from student";
Integer count = jdbcTemplate.queryForObject(sql, Integer.class);
System.out.println(count);
} @Test
public void testQueryOne() {
String sql = "select name from student where id = ?";
String name = jdbcTemplate.queryForObject(sql, String.class, 1004);
System.out.println(name);
}
  • queryForObject(String sql, Object[] args, RowMapper<T> rowMapper):该方法返回T类型的实体类,RowMapper的实现类定义返回结果与实体类之间的映射关系,第二个参数为占位符需要的参数。
  • queryForObject(String sql, RowMapper<T> rowMapper, Object... args):该方法返回T类型的实体类,RowMapper的实现类定义返回结果与实体类之间的映射关系,第三个参数为可变参数。
    @Test
public void testEntity() {
String sql = "select id, name, sex, born from student where id = ?";
Student student = jdbcTemplate.queryForObject(sql, new StudentRowMapper(), 1001);
System.out.println(student); }

  

  RowMapper的实现类如下

    private class StudentRowMapper implements RowMapper<Student>{

        @Override
public Student mapRow(ResultSet resultSet, int i) throws SQLException {
Student stud = new Student();
stud.setId(resultSet.getInt("id"));
stud.setName(resultSet.getString("name"));
stud.setSex(resultSet.getString("sex"));
stud.setBorn(resultSet.getDate("born"));
return stud;
}
}

5. queryForList:返回对象列表

  常用的重载方式如下:

  •   queryForList(String sql):返回类型为List<Map<String, Object>>。
  •   queryForList(String sql, Object... args):返回类型为List<Map<String, Object>>。
  • queryForList(String sql, Object[] args, Class<T> requiredType):返回指定类型的列表。
  • queryForList(String sql, Class<T> requiredType, Object... args):返回指定类型的列表。
    @Test
public void testQueryList() {
String sql = "select name from student"; List<String> nameList = jdbcTemplate.queryForList(sql, String.class);
System.out.println(nameList);
}
@Test
public void testQueryMapList() {
String sql = "select id, name from student where id between ? and ?";
List<Map<String, Object>> objList = jdbcTemplate.queryForList(sql, 1001, 1005);
System.out.println(objList);
}
 

6. queryForMap:返回Map对象

  常用的重载方式

  queryForMap(String sql):没有占位符。

  queryForMap(String sql, Object... args):第二个参数为可变参数。

    @Test
public void testQueryMap() {
String sql = "select id, name, born from student where id = ?";
Map<String, Object> studentMap = jdbcTemplate.queryForMap(sql, 1001);
System.out.println(studentMap);
}

7. query:返回对象列表

  常用的重载方法:

  •   query(String sql, RowMapper<T> rowMapper):rowMapper定义结果集和实体对象之间的映射关系。
  •   query(String sql, Object[] args, RowMapper<T> rowMapper):第二个参数定义占位符,第三个参数定义结果集和对象之间的映射关系。
  •   query(String sql, RowMapper<T> rowMapper, Object... args):第二个参数定义结果集合对象之间的映射关系,第三个参数为可变参数,定义占位符的值。
    @Test
public void testEntityList() { String sql = "select id, name, sex, born from student ";
List<Student> studentList = jdbcTemplate.query(sql, new StudentRowMapper());
System.out.println(studentList);
}

总结

  JdbcTemplate是在jdbc api的基础上进行了封装,提高了数据库访问的灵活性,但是Spring并没有对数据库访问做更多的事,而是留给专门的持久层框架来做这些事。所以JdbcTemplate也有一些jdbc api遗留的问题,如sql和java代码在一起编写。

在学习JdbcTemplate时,主要学习的是慕课网的视频,也参考了下面博客,非常感谢

https://blog.csdn.net/weixin_40001125/article/details/88538576

https://www.cnblogs.com/caoyc/p/5630622.html

Jdbc Template初步了解的更多相关文章

  1. JDBC Template

    JDBC Template 1. Spring JDBC Spring框架对JDBC的简单封装,提供了一个JDBCTemplate对象用来简化JDBC的开发 步骤: 导入jar包 创建JDBCTemp ...

  2. Spring框架学习10——JDBC Template 实现数据库操作

    为了简化持久化操作,Spring在JDBC API之上提供了JDBC Template组件. 1.添加依赖 添加Spring核心依赖,MySQL驱动 <!--Spring核心基础依赖--> ...

  3. SSM 实训笔记 -11- 使用 Spring MVC + JDBC Template 实现筛选、检索功能(maven)

    SSM 实训笔记 -11- 使用 Spring MVC + JDBC Template 实现筛选.检索功能(maven) 本篇是新建的一个数据库,新建的一个完整项目. 本篇内容: (1)使用 Spri ...

  4. Spring的JDBC Template

    Spring的JDBC Template(JDBC模板)简化JDBC API开发,使用上和Apache公司的DBUtils框架非常类似) 快速入门实例 1.创建项目后,导入Spring基础核心开发包. ...

  5. Unit06: Spring对JDBC的 整合支持 、 Spring+JDBC Template、Spring异常处理

    Unit06: Spring对JDBC的 整合支持 . Spring+JDBC Template .Spring异常处理 1. springmvc提供的异常处理机制 我们可以将异常抛给spring框架 ...

  6. spring学习笔记之---JDBC Template

    JDBC  Template(简化持久化操作) (一)创建项目 (1)Maven配置 <dependencies> <dependency> <groupId>ju ...

  7. JAVA JDBC Template的使用

    JAVA JDBC Template的使用 什么是Template? Spring框架对JDBC的简单封装.提供了一个JDBCTemplate对象简化JDBC的开发 Template使用步骤 导入ja ...

  8. jdbc事务、连接池概念、c3p0、Driud、JDBC Template、DBUtils

    JDBC 事务控制 什么是事务:一个包含多个步骤或者业务操作.如果这个业务或者多个步骤被事务管理,则这多个步骤要么同时成功,要么回滚(多个步骤同时执行失败),这多个步骤是一个整体,不可分割的. 操作: ...

  9. Spring之JDBC Template

    时间:2017-2-5 18:16 --Spring对不同持久化技术的支持Spring为各种支持的持久化技术都提供了简单操作的模板和回调.ORM持久化技术:    JDBC:        org.s ...

随机推荐

  1. celery 基础教程(一):工作流程,架构以及概念

    1.工作流程 celery通过消息进行通信,通常使用一个叫Broker(中间人)来协client(任务的发出者)和worker(任务的处理者). clients发出消息到队列中,broker将队列中的 ...

  2. 数据可视化之powerBI基础(七)一文带你熟悉PowerBI建模视图中的功能

    https://zhuanlan.zhihu.com/p/67316729 PowerBI 3月的更新,正式发布了建模视图,而之前只是预览功能.新的建模视图到底有什么用,下面带你认识一下它的主要功能. ...

  3. 数据可视化之powerBI技巧(十七)在Power BI中对数据进行分组

    根据某一个维度的数据,进行分组统计,是很常见的做法,比如按年龄对客户进行分组,按考试成绩进行分组统计等,这篇文章介绍一下,在PowerBI中如何对数据进行分组. 在PowerQuery编辑器中分组 在 ...

  4. python 面向对象专题(八):特殊方法 (一)__get__、__set__、__delete__ 描述符(一)

    https://www.cnblogs.com/flashBoxer/p/9771797.html 实现了 __get__.__set__ 或 __delete__ 方法的类是描述符.描述符的用法是, ...

  5. VMWare WorkStation中MacOS虛擬機無法啓動的問題

    關於MacOS虛擬機,在有VMWare重裝,升級以及MacOS更新時,都可能會造成破解補丁失效,因此儅Mac虛擬機無法啓動時,可以嘗試以下操作: 重新運行unlocker208中的win-instal ...

  6. Ethical Hacking - GAINING ACCESS(10)

    CLIENT SIDE ATTACKS Use if server-side attacks fail. If IP is probably useless. Require user interac ...

  7. 用scratch编程大炮打幽灵

    首先来看看效果: 是不是很炫酷呢?想知道具体程序的话请关注微信公众号!

  8. 题解 洛谷 P5385 【[Cnoi2019]须臾幻境】

    首先我们知道 \(n\) 个点的树有 \(n-1\) 条边,因此对于森林来说,其点数减边数即为树的个数.那么对于普通的图,求出其任意一个生成树森林,森林中树的个数即为原图中连通块的个数,也就是点数减边 ...

  9. 题解 洛谷 P4899 【[IOI2018] werewolf 狼人】

    先考虑狼形,其只能走编号小于\(R\)的点.若将每条边赋边权为其两端点编号的较大值,然后按最小生成树的顺序构建\(Kruskal\)重构树. 那么从原图的一个点\(x\)在树上倍增,到达满足要求且深度 ...

  10. python中if及if-else如何使用

    if 结构 if 结构允许程序做出选择,并根据不同的情况执行不同的操作 基本用法 比较运算符 根据 PEP 8 标准,比较运算符两侧应该各有一个空格,比如:5 == 3. PEP8 标准 ==(相等) ...