当前位置: 首页 > news >正文

【Java 进阶篇】使用 JDBCTemplate 执行 DQL 语句详解

在这里插入图片描述

在前面的文章中,我们已经学习了如何使用 Spring 的 JDBCTemplate 执行 DML(Data Manipulation Language)操作,包括插入、更新和删除操作。现在,让我们来深入了解如何使用 JDBCTemplate 执行 DQL(Data Query Language)语句,从数据库中检索数据。

什么是 DQL?

DQL 是 SQL 的一部分,它用于从数据库中检索(查询)数据而不对数据进行修改。主要的 SQL DQL 语句包括 SELECTFROMWHEREGROUP BYHAVINGORDER BY 等,用于指定要检索的数据、数据的来源、筛选条件、分组方式和排序方式等。

使用 JDBCTemplate 执行 DQL 语句

要使用 JDBCTemplate 执行 DQL 语句,我们需要创建一个 JdbcTemplate 对象并配置数据源。以下是一些步骤:

步骤 1:配置数据源

首先,我们需要配置一个数据源,以便 JDBCTemplate 能够获取数据库连接。Spring 支持多种数据源,例如 Apache Commons DBCP、HikariCP 和 C3P0 等。这里我们以 HikariCP 数据源为例进行配置。

import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;import javax.sql.DataSource;public class DataSourceConfig {public DataSource dataSource() {HikariConfig config = new HikariConfig();config.setJdbcUrl("jdbc:mysql://localhost:3306/mydatabase");config.setUsername("root");config.setPassword("password");return new HikariDataSource(config);}
}

步骤 2:创建 JdbcTemplate

接下来,我们需要创建一个 JdbcTemplate 对象,并将数据源传递给它。

import org.springframework.jdbc.core.JdbcTemplate;public class JdbcTemplateConfig {private DataSource dataSource;public JdbcTemplateConfig(DataSource dataSource) {this.dataSource = dataSource;}public JdbcTemplate jdbcTemplate() {return new JdbcTemplate(dataSource);}
}

步骤 3:执行查询语句

现在,我们可以使用 JDBCTemplate 执行 DQL 查询语句了。以下是一个示例,演示如何查询数据库中的员工信息:

import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;public class EmployeeDao {private JdbcTemplate jdbcTemplate;public EmployeeDao(JdbcTemplate jdbcTemplate) {this.jdbcTemplate = jdbcTemplate;}public List<Employee> getAllEmployees() {String sql = "SELECT * FROM employees";return jdbcTemplate.query(sql, new EmployeeRowMapper());}
}class EmployeeRowMapper implements RowMapper<Employee> {@Overridepublic Employee mapRow(ResultSet rs, int rowNum) throws SQLException {Employee employee = new Employee();employee.setId(rs.getInt("id"));employee.setFirstName(rs.getString("first_name"));employee.setLastName(rs.getString("last_name"));employee.setEmail(rs.getString("email"));return employee;}
}

在上述示例中,我们创建了一个 EmployeeDao 类,其中的 getAllEmployees 方法执行了一个 SQL 查询语句,使用 query 方法将查询结果映射到 Employee 对象列表中。

示例代码

下面是一个完整的示例代码,演示了如何使用 JDBCTemplate 执行 DQL 查询语句:

import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;import javax.sql.DataSource;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;public class Main {public static void main(String[] args) {// 步骤 1:配置数据源DataSource dataSource = configureDataSource();// 步骤 2:创建 JdbcTemplateJdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);// 步骤 3:执行查询EmployeeDao employeeDao = new EmployeeDao(jdbcTemplate);List<Employee> employees = employeeDao.getAllEmployees();// 打印查询结果for (Employee employee : employees) {System.out.println("Employee ID: " + employee.getId());System.out.println("First Name: " + employee.getFirstName());System.out.println("Last Name: " + employee.getLastName());System.out.println("Email: " + employee.getEmail());System.out.println();}}private static DataSource configureDataSource() {HikariConfig config = new HikariConfig();config.setJdbcUrl("jdbc:mysql://localhost:3306/mydatabase");config.setUsername("root");config.setPassword("password");return new HikariDataSource(config);}
}class Employee {private int id;private String firstName;private String lastName;private String email;// 省略 getter 和 setter 方法
}class EmployeeDao {private JdbcTemplate jdbcTemplate;public EmployeeDao(JdbcTemplate jdbcTemplate) {this.jdbcTemplate = jdbcTemplate;}public List<Employee> getAllEmployees() {String sql = "SELECT * FROM employees";return jdbcTemplate.query(sql, new EmployeeRowMapper());}
}class EmployeeRowMapper implements RowMapper<Employee> {@Overridepublic Employee mapRow(ResultSet rs, int rowNum) throws SQLException {Employee employee = new Employee();employee.setId(rs.getInt("id"));employee.setFirstName(rs.getString("first_name"));employee.setLastName(rs.getString("last_name"));employee.setEmail(rs.getString("email"));return employee;}
}

总结

在本文中,我们学习了如何使用 Spring 的 JDBCTemplate 执行 DQL 查询语句。首先,我们配置了数据源,然后创建了 JdbcTemplate 对象,最后执行了一个简单的查询操作,并将查询结果映射到 Java 对象中。通过这种方式,我们可以方便地与数据库交互,检索所需的数据。

希望本文能帮助你更好地理解如何使用 JDBCTemplate 执行 DQL 查询操作,并在实际项目中应用这些知识。

如果你想要深入学习 Spring JDBC,还可以研究更高级的主题,例如分页查询、存储过程调用和高级映射等。祝你在使用 Spring JDBC 进行数据库操作时取得成功!

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191
http://www.lryc.cn/news/183684.html

相关文章:

  • 了解了spring mvc web容器中一个http请求的全过程,能给我们提升多少武力值
  • 【BBC新闻文章分类】使用 TF 2.0和 LSTM 的文本分类
  • set和map的封装
  • java基础练习--基础语法
  • Android12 OTA编译差分包报错问题
  • 现代c++手撸2309神经网络最简化版230901
  • Qt之显示PDF文件
  • [极客大挑战 2019]FinalSQL - 异或盲注
  • 【Go语言实战】(25) 分布式算法 MapReduce
  • 【网络安全-信息收集】网络安全之信息收集和信息收集工具讲解(提供工具)
  • 战火使命ssr排名,战火使命角色强度排行
  • CSS之linear-gradient( ) 函数—背景颜色渐变设计
  • [Unity]未能加载一个或多个断点问题
  • Qt中的基础数据类型
  • 2023阿里云域名优惠口令大全
  • 湖南软件测评公司简析:软件功能测试和非功能测试的联系和区别
  • HuggingFace Transformers教程(1)--使用AutoClass加载预训练实例
  • Qt获取当前所用的Qt版本、编译器、位数等信息
  • 《C和指针》笔记31:多维数组的数组名、指向多维数组的指针、作为函数参数的多维数组
  • 【伪彩色图像处理】将灰度图像转换为彩色图像研究(Matlab代码实现)
  • Go Gin Gorm Casbin权限管理实现 - 2. 使用Gorm存储Casbin权限配置以及`增删改查`
  • DNDC模型的温室气体排放分析
  • vue、全局前置守卫
  • OpenWRT、Yocto 、Buildroot和Ubuntu有什么区别
  • 数据挖掘(3)特征化
  • 【RabbitMQ 实战】08 集群原理剖析
  • 2023年 2月3月 工作经历
  • selenium京东商城爬取
  • 用pandas处理数据时,使变量能够在不同的Notebook会话页面进行传递,魔法命令%store
  • 选择适合户外篷房企业的企业云盘解决方案