JAVAEE框架之Spring JdbcTemplate

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: JAVAEE框架之Spring JdbcTemplate

七.JdbcTemplate

概念:Spring对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中。目的是使JDBC更加易于使用。JdbcTemplate是Spring的一部分。 JdbcTemplate处理了资源的建立和释放。

作用:

1.不需要管理连接

2.不需要设置参数

3.可以返回实体类

常用方法:

  • execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;
  • update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;
  • query方法及queryForXXX方法:用于执行查询相关语句;
  • call方法: 用于执行存储过程、函数相关语句。

7.1使用步骤

准备工作:要有数据库、数据表

hr库,大家也可以自己建立一个数据库、数据表。

7.1.1 导入jar依赖

<!--导入相应的jar依赖-->
<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>5.2.5.RELEASE</version>
    </dependency>
    <!--增加spring-jdbc的依赖-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>5.2.5.RELEASE</version>
    </dependency>
    <!--增加对mysql 连接的jar依赖-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.19</version>
        </dependency>
    <!--增加对junit的jar依赖-->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.13</version>
    </dependency>
</dependencies>

7.1.2 配置数据源

数据源是什么???DataSource

//1.spring jdbc数据源;看下这个单词:DriverManager +DataSource
DriverManagerDataSource dataSource=new DriverManagerDataSource();
//手动设置驱动 url  用户名 密码;如果你的是5.1; com.mysql.jdbc.Driver
dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/hr");
dataSource.setUsername("root");
dataSource.setPassword("root");

7.1.3 创建JdbcTemplate对象

//2.创建JdbcTemplate对象;
JdbcTemplate jdbcTemplate=new JdbcTemplate(); //new JdbcTemplate(dataSource)
jdbcTemplate.setDataSource(dataSource); //将上面的数据源对象,建立和JdbcTemplate对象的关联;

7.1.4 执行 增删改操作

//3.执行增删改查的操作;
jdbcTemplate.execute("delete  from account where id=1");

存在的问题是什么呢???

1.数据库配置的代码,放到了java里面,根据“高内聚,低耦合”原则,应该尽量做到分离;

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
    <!--通过spring配置文件来实现低耦合-->
    <!--1.配置DataSource数据源-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/hr?useTimezone=true&amp;serverTimezone=CTT&amp;useUnicode=true&amp;characterEncoding=utf8&amp;useSSL=false"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>
    <!--配置JdbcTemplate-->
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <!--这个对应setDataSource方法,将set后的方法名首字母小写-->
        <property name="dataSource" ref="dataSource"/>
    </bean>
</beans>

测试类:

//1.要通过Spring来访问xml;new 完之后,Alt+Enter自动出来前面的变量名,然后名字可以自行修改
       ClassPathXmlApplicationContext  ac= new ClassPathXmlApplicationContext("beans.xml");
        //2.通过spring 配置文件来获取响应的对象
       JdbcTemplate jdbcTemplate= (JdbcTemplate) ac.getBean("jdbcTemplate");
jdbcTemplate.update("insert account(uid,money) values (10,99999)");
System.out.println("插入数据完毕");

针对Junit的知识点扩充:

额外的补充了一个知识点:

@Before:void方法之前

@After: void方法之后

@Test:用于单元测试的void方法

import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.jdbc.core.JdbcTemplate;
/**
 * Created by 张晨光 on 2020/6/29 15:52
 */
public class TestJdbcTemplateTwo {
    ClassPathXmlApplicationContext ac;
    JdbcTemplate jdbcTemplate;
    /**
     * 这个注解是在junit单元测试,常规的void方法之前进行;
     */
    @Before
    public void before(){
        System.out.println("开始了...");
        //1.要通过Spring来访问xml;new 完之后,Alt+Enter自动出来前面的变量名,然后名字可以自行修改
         ac= new ClassPathXmlApplicationContext("beans.xml");
        //2.通过spring 配置文件来获取响应的对象
        jdbcTemplate= (JdbcTemplate) ac.getBean("jdbcTemplate");
    }
    /**
     * 这个注解是在junit单元测试,常规的void方法之后进行;
     */
    @After
    public void after(){
        System.out.println("整体结束...");
    }
    @Test
    public void test(){        //3.执行操作--》增加操作;
        jdbcTemplate.update("insert account(uid,money) values (10,99999)");
        System.out.println("插入数据完毕");
    }
    @Test
    public void testUpdate(){
        //3.执行操作--》增加操作;
        jdbcTemplate.update("update account set money=9988 where uid=10");
        System.out.println("更新数据完毕");
    }
    @Test
    public void testDelete(){
        //3.执行操作--》增加操作;
        jdbcTemplate.update("delete  from account where uid=10");
        System.out.println("删除数据完毕");
    }
}

2.要扩充连接池技术,下次讲;

“低耦合"实现,使用Spring框架

总结:

1.已经学习过了Spring框架,对于复杂的企业业务逻辑,进行解耦操作,降低系统的复杂度;

2.Spring框架封装了原生 JDBC,就是JdbcTemplate,可以实现对数据库的增删改查操作,注意需要依赖于DataSource数据源类;

作业:

使用spring来对JdbcTemplate进行注入,实现增删改业务操作。

7.2 RowMapper

Spring提供的对数据库查询数据封装的接口。

通过实现接口,实现接口mapRow方法(),通过对数据的封装就是通过mapRow方法实现

@FunctionalInterface
public interface RowMapper<T> {
    @Nullable
    T mapRow(ResultSet var1, int var2) throws SQLException;
}

BeanPropertyRowMapper这是对RowMapper的实现类,它可以把ResultSet和实体类的字段进行实现自动映射,可以给同名字段进行封装。自动将一行数据映射到指定类的实例, 首先将这个类实例化,然后通过名称匹配的方式,映射到属性中去。

7.2.1 查询数据

//需要提前去预习知识点:RowMapper
//        List<Account> accounts = jdbcTemplate.query("select * from account where money>?", new AccountRowMapper(), 2200);
        /*List<Account> accounts = jdbcTemplate.query("select * from account where money>?", new BeanPropertyRowMapper<Account>(Account.class), 2200);
        for(Account account:accounts){
            System.out.println(account);
        }*/
        //单一的账户
        /*List<Account> accounts = jdbcTemplate.query("select * from account where money=?", new BeanPropertyRowMapper<Account>(Account.class), 8899);
        System.out.println(accounts.get(0));*/
        //返回一行一列的数据;
        Integer count=jdbcTemplate.queryForObject("select Max(money) from account where money>?", Integer.class, 2200);
        System.out.println(count);

7.2.2 分层设计实现

作;
jdbcTemplate.update(“delete from account where uid=10”);
System.out.println(“删除数据完毕”);
}
}
2.要扩充连接池技术,下次讲;
“低耦合"实现,使用Spring框架
总结:
1.已经学习过了Spring框架,对于复杂的企业业务逻辑,进行解耦操作,降低系统的复杂度;
2.Spring框架封装了原生 JDBC,就是JdbcTemplate,可以实现对数据库的增删改查操作,注意需要依赖于DataSource数据源类;
作业:
使用spring来对JdbcTemplate进行注入,实现增删改业务操作。
## 7.2 RowMapper
> Spring提供的对数据库查询数据封装的接口。
>
> 通过实现接口,实现接口mapRow方法(),通过对数据的封装就是通过mapRow方法实现
@FunctionalInterface
public interface RowMapper {
@Nullable
T mapRow(ResultSet var1, int var2) throws SQLException;
}
BeanPropertyRowMapper这是对RowMapper的实现类,它可以把ResultSet和实体类的字段进行实现自动映射,可以给同名字段进行封装。自动将一行数据映射到指定类的实例, 首先将这个类实例化,然后通过名称匹配的方式,映射到属性中去。
### 7.2.1 查询数据
//需要提前去预习知识点:RowMapper
// List accounts = jdbcTemplate.query(“select * from account where money>?”, new AccountRowMapper(), 2200);
/List accounts = jdbcTemplate.query(“select * from account where money>?”, new BeanPropertyRowMapper(Account.class), 2200);
for(Account account:accounts){
System.out.println(account);
}/
//单一的账户
/List accounts = jdbcTemplate.query(“select * from account where money=?”, new BeanPropertyRowMapper(Account.class), 8899);
System.out.println(accounts.get(0));/
//返回一行一列的数据;
Integer count=jdbcTemplate.queryForObject(“select Max(money) from account where money>?”, Integer.class, 2200);
System.out.println(count);
### 7.2.2 分层设计实现


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
23天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
1月前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
37 0
|
27天前
|
前端开发 Java 数据库连接
Spring 框架:Java 开发者的春天
Spring 框架是一个功能强大的开源框架,主要用于简化 Java 企业级应用的开发,由被称为“Spring 之父”的 Rod Johnson 于 2002 年提出并创立,并由Pivotal团队维护。
43 1
Spring 框架:Java 开发者的春天
|
19天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
37 2
|
19天前
|
消息中间件 NoSQL Java
springboot整合常用中间件框架案例
该项目是Spring Boot集成整合案例,涵盖多种中间件的使用示例,每个案例项目使用最小依赖,便于直接应用到自己的项目中。包括MyBatis、Redis、MongoDB、MQ、ES等的整合示例。
76 1
|
27天前
|
Java 数据库连接 开发者
Spring 框架:Java 开发者的春天
【10月更文挑战第27天】Spring 框架由 Rod Johnson 在 2002 年创建,旨在解决 Java 企业级开发中的复杂性问题。它通过控制反转(IOC)和面向切面的编程(AOP)等核心机制,提供了轻量级的容器和丰富的功能,支持 Web 开发、数据访问等领域,显著提高了开发效率和应用的可维护性。Spring 拥有强大的社区支持和丰富的生态系统,是 Java 开发不可或缺的工具。
|
1月前
|
人工智能 开发框架 Java
总计 30 万奖金,Spring AI Alibaba 应用框架挑战赛开赛
Spring AI Alibaba 应用框架挑战赛邀请广大开发者参与开源项目的共建,助力项目快速发展,掌握 AI 应用开发模式。大赛分为《支持 Spring AI Alibaba 应用可视化调试与追踪本地工具》和《基于 Flow 的 AI 编排机制设计与实现》两个赛道,总计 30 万奖金。
|
Java Spring
spring框架之AOP模块(面向切面),附带通知类型---超详细介绍
spring框架之AOP模块(面向切面),附带通知类型---超详细介绍
122 0
|
缓存 监控 Java
Spring框架之AOP(面向切面编程)
Spring框架之AOP(面向切面编程)
58 0
|
4月前
|
分布式计算 Java MaxCompute
详解 Java 限流接口实现问题之在Spring框架中使用AOP来实现基于注解的限流问题如何解决
详解 Java 限流接口实现问题之在Spring框架中使用AOP来实现基于注解的限流问题如何解决