如何使用 Spring Boot 3.3 和 JdbcTemplate 操作 MySQL 数据库

 更新时间:2025年06月09日 11:07:27   作者:喜欢踢足球的老罗  
本文介绍了如何在Spring Boot 3.3项目中使用 JdbcTemplate操作 MySQL数据库,通过RowMapper接口,我们将查询结果映射为User对象,感兴趣的朋友跟随小编一起看看吧

在现代的 Java 应用开发中,Spring Boot 提供了强大的工具来简化数据库操作。JdbcTemplate 是 Spring 提供的一个核心类,用于简化 JDBC 操作,减少样板代码。本文将介绍如何在 Spring Boot 3.3 项目中使用 JdbcTemplate 来操作 MySQL 数据库,并通过类图展示关键类之间的关系。

1. 项目依赖配置

在 Spring Boot 3.3 项目中,使用 JdbcTemplate 操作 MySQL 数据库需要以下依赖:
spring-boot-starter-jdbc:提供 JdbcTemplate 和其他 JDBC 相关功能。
mysql-connector-j:MySQL 的 JDBC 驱动,用于连接 MySQL 数据库。
在 pom.xml 文件中添加以下依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-j</artifactId>
    <scope>runtime</scope>
</dependency>

2. 数据库配置

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/your_database?useSSL=false&serverTimezone=UTC
    username: your_username
    password: your_password
    driver-class-name: com.mysql.cj.jdbc.Driver

3. 关键类及其关系

3.1 实体类(User)

实体类 User 对应数据库表 users。它包含字段 id、name 和 email,以及相应的 getter 和 setter 方法。

public class User {
    private Long id;
    private String name;
    private String email;
    // Getters and Setters
    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
}

3.2 DAO 类(UserDao)

DAO 类 UserDao 封装了与数据库表相关的操作。它注入了 JdbcTemplate 对象,并通过它执行 SQL 语句。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public class UserDao {
    @Autowired
    private JdbcTemplate jdbcTemplate;
    public User findUserById(Long id) {
        String sql = "SELECT * FROM users WHERE id = ?";
        return jdbcTemplate.queryForObject(sql, new Object[]{id}, new UserRowMapper());
    }
    public List<User> findAllUsers() {
        String sql = "SELECT * FROM users";
        return jdbcTemplate.query(sql, new UserRowMapper());
    }
    public int insertUser(User user) {
        String sql = "INSERT INTO users (name, email) VALUES (?, ?)";
        return jdbcTemplate.update(sql, user.getName(), user.getEmail());
    }
    public int updateUser(User user) {
        String sql = "UPDATE users SET name = ?, email = ? WHERE id = ?";
        return jdbcTemplate.update(sql, user.getName(), user.getEmail(), user.getId());
    }
    public int deleteUser(Long id) {
        String sql = "DELETE FROM users WHERE id = ?";
        return jdbcTemplate.update(sql, id);
    }
}

3.3 RowMapper 接口

RowMapper 是一个接口,用于将 ResultSet 中的每一行数据映射为一个对象。UserRowMapper 是 RowMapper 的具体实现,用于将查询结果映射为 User 对象。

import org.springframework.jdbc.core.RowMapper;
import java.sql.ResultSet;
import java.sql.SQLException;
public class UserRowMapper implements RowMapper<User> {
    @Override
    public User mapRow(ResultSet rs, int rowNum) throws SQLException {
        User user = new User();
        user.setId(rs.getLong("id"));
        user.setName(rs.getString("name"));
        user.setEmail(rs.getString("email"));
        return user;
    }
}

4. 注意事项

4.1 SQL 注入风险

确保使用参数化查询,避免直接拼接 SQL 语句,以防止 SQL 注入攻击。

4.2 异常处理

捕获并处理可能的 DataAccessException,这是 JdbcTemplate 抛出的异常。

4.3 资源管理

JdbcTemplate 会自动管理数据库连接,无需手动关闭 Connection、Statement 或 ResultSet。

4.4 性能优化

对于复杂的查询,可以考虑使用 PreparedStatement 或 PreparedStatementSetter 来提高性能。

5. 总结

本文介绍了如何在 Spring Boot 3.3 项目中使用 JdbcTemplate 操作 MySQL 数据库。我们定义了实体类 User,创建了 DAO 类 UserDao,并使用 JdbcTemplate 执行数据库操作。通过 RowMapper 接口,我们将查询结果映射为 User 对象。最后,我们通过类图展示了关键类之间的关系。
希望本文对你有所帮助!如果有任何问题或建议,欢迎随时留言。

PS:以我之思,借AI之力

到此这篇关于如何使用 Spring Boot 3.3 和 JdbcTemplate 操作 MySQL 数据库的文章就介绍到这了,更多相关Spring Boot JdbcTemplate操作mysql内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java使用opencv识别二维码的完整步骤

    Java使用opencv识别二维码的完整步骤

    OpenMV是一个开源,低成本,功能强大的机器视觉模块,下面这篇文章主要给大家介绍了关于Java使用opencv识别二维码的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-09-09
  • java判断ftp目录是否存在的方法

    java判断ftp目录是否存在的方法

    这篇文章主要为大家详细介绍了java判断ftp目录是否存在的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • java实现JSON字符串格式化输出

    java实现JSON字符串格式化输出

    这篇文章主要为大家详细介绍了如何使用java实现JSON字符串格式化输出,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以了解下
    2024-01-01
  • 深入浅析Netty 在 Dubbo 中是如何应用的

    深入浅析Netty 在 Dubbo 中是如何应用的

    国内知名框架 Dubbo 底层使用的是 Netty 作为网络通信,那么内部到底是如何使用的呢?今天通过本文给大家详细讲解,对Netty 在 Dubbo中应用相关知识感兴趣的朋友跟随小编一起看看吧
    2020-05-05
  • Java并发系列之CyclicBarrier源码分析

    Java并发系列之CyclicBarrier源码分析

    这篇文章主要为大家详细分析了Java并发系列之CyclicBarrier源码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • 一文掌握Springboot集成RabbitMQ的方法

    一文掌握Springboot集成RabbitMQ的方法

    RabbitMQ是开源的消息队列服务器,实现了AMQP高级消息队列协议标准,AMQP 是一种应用层协议,为面向消息的中间件设计,基于此协议的客户端与消息中间件可传递消息,并不受产品、开发语言等条件的限制,这篇文章主要介绍了Springboot集成RabbitMQ的过程,需要的朋友可以参考下
    2024-04-04
  • Java的编译时错误和运行时错误问题

    Java的编译时错误和运行时错误问题

    这篇文章主要介绍了Java的编译时错误和运行时错误问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 通过实例解析Socket套接字通信原理

    通过实例解析Socket套接字通信原理

    这篇文章主要介绍了通过实例解析Socket套接字通信原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-12-12
  • Java实现跨服务器上传文件功能

    Java实现跨服务器上传文件功能

    这篇文章主要为大家详细介绍了Java实现跨服务器上传文件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Mybatis-Plus雪花id的使用以及解析机器ID和数据标识ID实现

    Mybatis-Plus雪花id的使用以及解析机器ID和数据标识ID实现

    这篇文章主要介绍了Mybatis-Plus雪花id的使用以及解析机器ID和数据标识ID实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08

最新评论