一文解析Spring JDBC Template的使用指导

一文,解析,spring,jdbc,template,使用,指导 · 浏览次数 : 236

小编点评

**摘要** 本文介绍了Spring框架对JDBC的简单封装,包括以下步骤: 1. **导入jar包** 2. **创建JdbcTemplate对象** 3. **执行CRUD操作** 4. **使用BeanPropertyRowMapper自动封装对象** 5. **使用QueryForList和QueryForObject查询所有记录** 6. **使用QueryForMap查询单个记录** **代码示例** ```java JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource()); // 修改1号数据的 salary template.update("update emp set salary = 10000 where id = 1", 1); // 添加一条记录 template.insert("insert into emp(name,dept_id) values(?,?)", "郭靖", 1); // 删除刚才添加的记录 template.update("delete from emp where id = ?", 7); // 查询id为1的记录,将其封装为Map集合 Map map = template.queryForMap("select * from emp where id = ?", 1); // 查询所有记录,将其封装为List集合 List> list = template.queryForList("select * from emp"); // 查询所有记录,将其封装为Emp对象的List集合 List empList = template.query(sql, new BeanPropertyRowMapper(Emp.class)); ``` **注意** * 这只是一个简单的示例,您可以根据您的需求进行修改。 * 您可以使用其他 RowMapper实现类,例如 BeanPropertyRowMapper 和 ListRowMapper。 * 您可以使用其他查询方法,例如 queryForObject 和 queryForMap,以获取不同的结果。

正文

摘要:Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发。

本文分享自华为云社区《Spring JdbcTemplate使用解析》,作者: 共饮一杯无 。

Spring框架对JDBC的简单封装。提供了一个JDBC Template对象简化JDBC的开发

步骤

1.导入jar包

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

2. 创建JdbcTemplate对象。依赖于数据源DataSource

JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());

调用JdbcTemplate的方法来完成CRUD的操作

update():执行DML语句。增、删、改语句
queryForMap():查询结果将结果集封装为map集合,将列名作为key,将值作为value 将这条记录封装为一个map集合

注意:这个方法查询的结果集长度只能是1

queryForList():查询结果将结果集封装为list集合

注意:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中

query():查询结果,将结果封装为JavaBean对象

query的参数:RowMapper

一般我们使用BeanPropertyRowMapper实现类。可以完成数据到JavaBean的自动封装

new BeanPropertyRowMapper<类型>(类型.class)

queryForObject:查询结果,将结果封装为对象

一般用于聚合函数的查询

练习

需求

  1. 修改1号数据的 salary 为 10000
  2. 添加一条记录
  3. 删除刚才添加的记录
  4. 查询id为1的记录,将其封装为Map集合
  5. 查询所有记录,将其封装为List
  6. 查询所有记录,将其封装为Emp对象的List集合
  7. 查询总记录数

代码

import com.zjq.javabase.base27.domain.Emp;
import com.zjq.javabase.base27.utils.JDBCUtils;
import org.junit.Test;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import java.sql.Date;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;
/**
 * JdbcTemplate入门
 *
 * @author zjq
 */
public class JdbcTemplateDemo2 {
 //1. 获取JDBCTemplate对象
 private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
 /**
     * 1. 修改1号数据的 salary 为 10000
     */
 @Test
 public void test1() {
 //2. 定义sql
 String sql = "update emp set salary = 10000 where id = 1";
 //3. 执行sql
 int count = template.update(sql);
 System.out.println(count);
 }
 /**
     * 2. 添加一条记录
     */
 @Test
 public void test2() {
 String sql = "insert into emp(name,dept_id) values(?,?)";
 int count = template.update(sql, "郭靖", 1);
 System.out.println(count);
 }
 /**
     * 3.删除刚才添加的记录
     */
 @Test
 public void test3() {
 String sql = "delete from emp where id = ?";
 int count = template.update(sql, 7);
 System.out.println(count);
 }
 /**
     * 4.查询id为1的记录,将其封装为Map集合
     * 注意:这个方法查询的结果集长度只能是1
     */
 @Test
 public void test4() {
 String sql = "select * from emp where id = ? ";
 Map<String, Object> map = template.queryForMap(sql, 1);
 System.out.println(map);
 //{id=1, ename=孙悟空, job_id=4, mgr=1004, joindate=2000-12-17, salary=10000.00, bonus=null, dept_id=20}
 }
 /**
     * 5. 查询所有记录,将其封装为List
     */
 @Test
 public void test5() {
 String sql = "select * from emp";
 List<Map<String, Object>> list = template.queryForList(sql);
 for (Map<String, Object> stringObjectMap : list) {
 System.out.println(stringObjectMap);
 }
 }
 /**
     * 6. 查询所有记录,将其封装为Emp对象的List集合
     */
 @Test
 public void test6() {
 String sql = "select * from emp";
 List<Emp> list = template.query(sql, new RowMapper<Emp>() {
 @Override
 public Emp mapRow(ResultSet rs, int i) throws SQLException {
 Emp emp = new Emp();
 int id = rs.getInt("id");
 String ename = rs.getString("NAME");
 String gender = rs.getString("gender");
 Date joindate = rs.getDate("join_date");
 double salary = rs.getDouble("salary");
 int dept_id = rs.getInt("dept_id");
 emp.setId(id);
 emp.setName(ename);
 emp.setGender(gender);
 emp.setJoindate(joindate);
 emp.setSalary(salary);
 emp.setDept_id(dept_id);
 return emp;
 }
 });
 for (Emp emp : list) {
 System.out.println(emp);
 }
 }
 /**
     * 6. 查询所有记录,将其封装为Emp对象的List集合
     */
 @Test
 public void test6_2() {
 String sql = "select * from emp";
 List<Emp> list = template.query(sql, new BeanPropertyRowMapper<Emp>(Emp.class));
 for (Emp emp : list) {
 System.out.println(emp);
 }
 }
 /**
     * 7. 查询总记录数
     */
 @Test
 public void test7() {
 String sql = "select count(id) from emp";
 Long total = template.queryForObject(sql, Long.class);
 System.out.println(total);
 }
}

 

点击关注,第一时间了解华为云新鲜技术~

与一文解析Spring JDBC Template的使用指导相似的内容:

一文解析Spring JDBC Template的使用指导

摘要:Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简化JDBC的开发。 本文分享自华为云社区《Spring JdbcTemplate使用解析》,作者: 共饮一杯无 。 Spring框架对JDBC的简单封装。提供了一个JDBC Template对象简化JDBC的开发 步

一文详解RocketMQ-Spring的源码解析与实战

摘要:这篇文章主要介绍 Spring Boot 项目使用 rocketmq-spring SDK 实现消息收发的操作流程,同时笔者会从开发者的角度解读 SDK 的设计逻辑。 本文分享自华为云社区《RocketMQ-Spring : 实战与源码解析一网打尽》,作者:勇哥java实战分享。 Rocket

【转帖】一文解析ethtool 命令的使用

命令简介 ethtool命令用于查询和控制网络设备驱动程序和硬件设置,尤其是有线以太网设备,devname网卡的名称。网卡就像是交换机的一个端口,正常使用我们只是配置网卡IP地址等信息,网卡的速率、双工模式等我们并不关心。通过ethtool命令我们可以像配置交换机网卡一样配置这些参数,这就是这个命令

实例解析丨一文搞定GaussDB CM服务异常

摘要:本文主要为大家带来如何处理GaussDB CM服务异常问题。 本文分享自华为云社区《【实例状态】GaussDB CM服务异常》,作者:酷哥。 首先确认是否是虚拟机、网络故障,底层故障处理 PID文件未清理导致进程启动失败 问题现象 收到告警CM服务异常,查看集群状态,CM节点显示DOWN 问题

[转帖]BPF CO-RE 示例代码解析

https://www.cnblogs.com/charlieroro/p/14357802.html 在BPF的可移植性和CO-RE一文的末尾提到了一个名为runqslower的工具,该工具用于展示在CPU run队列中停留的时间大于某一值的任务。现在以该工具来展示如何使用BPF CO-RE。 目

一文掌握Python多线程与多进程

# Python的多线程和多进程 ## 一、简介 并发是今天计算机编程中的一项重要能力,尤其是在面对需要大量计算或I/O操作的任务时。Python 提供了多种并发的处理方式,本篇文章将深入探讨其中的两种:多线程与多进程,解析其使用场景、优点、缺点,并结合代码例子深入解读。 ## 二、多线程 Pyth

一文详解自然语言处理两大任务与代码实战:NLU与NLG

> 自然语言处理(NLP)涵盖了从基础理论到实际应用的广泛领域,本文深入探讨了NLP的关键概念,包括词向量、文本预处理、自然语言理解与生成、统计与规则驱动方法等,为读者提供了全面而深入的视角。 > 作者 TechLead,拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦

一文搞懂 x64 IA-64 AMD64 Inte64 IA-32e 架构之间的关系

一文搞懂 x64 IA-64 AMD64 Inte64 IA-32e 架构之间的关系

[转帖]一文搞懂不同方式Redis集群搭建

https://bbs.huaweicloud.com/blogs/380521 【摘要】 1 实验环境准备 1.1 构建Redis的Docker镜像[root@iZ2ze4m2ri7irkf6h6n8zoZ redis]# docker pull redis[root@iZ2ze4m2ri7irk

[转帖]一文看懂家庭宽带光纤是如何入户

目前,家庭宽带普遍实现了光纤入户,入户光纤一般在弱电箱的位置,家庭装修需要预埋网线,才能在后期流畅的使用网络。下文对网线预埋、网线选择、组网方式三个方面说一说。 一、光纤如何入户 1、光纤如何入户 入户光纤是不用家庭用户操心的,运营商在小区附件,一般部署了分光箱等。装机员会从分光箱拉一条皮纤到房子的