”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 数据库与 Spring Boot 集成:最佳实践和工具

数据库与 Spring Boot 集成:最佳实践和工具

发布于2024-07-30
浏览:260

Database Integration with Spring Boot : Best Practices and Tools

将数据库与 Spring Boot 应用程序集成是许多开发人员执行的常见任务。 Spring Boot 与 Spring Data JPA 相结合,提供了一个强大的框架来使用 MySQL 等关系数据库。此外,Flyway 和 Liquibase 等工具有助于高效管理数据库迁移。本博客将介绍使用 Spring Data JPA 与关系数据库、与 MySQL 集成以及使用 Flyway 或 Liquibase 管理数据库迁移的最佳实践

将 Spring Data JPA 与关系数据库结合使用
Spring Data JPA 通过减少样板代码量来简化数据访问层的实现。它为各种数据存储提供了强大的存储库抽象,使数据库交互更加简单

使用 Spring Data JPA 的最佳实践:

与 MySQL 等 SQL 数据库集成:
MySQL 是最流行的关系数据库之一,将其与 Spring Boot 集成非常简单。

将 MySQL 与 Spring Boot 集成的步骤:
添加依赖项: 在 pom.xml 中添加 Spring Data JPA 和 MySQL 连接器所需的依赖项


    org.springframework.boot
    spring-boot-starter-data-jpa


    mysql
    mysql-connector-java


数据库配置: 在 application.properties 或 application.yml 中配置数据库连接详细信息

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/mydatabase
    username: root
    password: rootpassword
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    hibernate:
      ddl-auto: update
    show-sql: true

定义您的实体: 首先定义您的 JPA 实体 每个实体代表数据库中的一个表

@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column(nullable = false)
    private String name;

    @Column(unique = true, nullable = false)
    private String email;

    // Getters and Setters
}

创建存储库:创建存储库接口来执行CRUD操作。扩展 JpaRepository 以利用内置方法和自定义查询方法

public interface UserRepository extends JpaRepository {
    Optional findByEmail(String email);
}

创建服务层:使用服务层封装业务逻辑并与存储库交互

@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    // Create operation
    public User createUser(User user) {
        // Perform validation or business logic if needed
        return userRepository.save(user);
    }

    // Read operations

    public Optional findUserById(Long id) {
        return userRepository.findById(id);
    }

    public Optional findUserByEmail(String email) {
        return userRepository.findByEmail(email);
    }

    public List getAllUsers() {
        return userRepository.findAll();
    }

    // Update operation
    public User updateUser(Long id, User userDetails) {
        // Ensure the user exists
        User existingUser = userRepository.findById(id)
                .orElseThrow(() -> new ResourceNotFoundException("User not found with id: "   id));

        // Update user details
        existingUser.setName(userDetails.getName());
        existingUser.setEmail(userDetails.getEmail());

        // Save updated user
        return userRepository.save(existingUser);
    }

    // Delete operation
    public void deleteUser(Long id) {
        // Ensure the user exists
        User existingUser = userRepository.findById(id)
                .orElseThrow(() -> new ResourceNotFoundException("User not found with id: "   id));

        // Delete user
        userRepository.delete(existingUser);
    }
}

异常处理 :
在 updateUser 和 deleteUser 方法中,您可能需要处理具有指定 ID 的用户不存在的情况。您可以创建自定义异常(例如 ResourceNotFoundException)并在必要时抛出它

@ResponseStatus(HttpStatus.NOT_FOUND)
public class ResourceNotFoundException extends RuntimeException {
    public ResourceNotFoundException(String message) {
        super(message);
    }
}

运行MySQL服务器:确保MySQL服务器正在运行,并且指定的数据库(mydatabase)存在。您可以使用 MySQL CLI 或 GUI 工具(例如 MySQL Workbench

)创建数据库

测试连接:运行 Spring Boot 应用程序以验证与 MySQL 数据库的连接。如果配置正确,Spring Boot 将根据您的实体自动创建必要的表

使用 Flyway 或 Liquibase 进行数据库迁移:
管理数据库模式更改对于维护应用程序的完整性和一致性至关重要。 Flyway 和 Liquibase 是处理数据库迁移的两种流行工具。

使用 Flyway 进行数据库迁移
Flyway是一个使用SQL脚本来管理数据库版本控制的迁移工具

添加依赖项: 将 Flyway 依赖项添加到您的 pom.xml


    org.flywaydb
    flyway-core


配置Flyway : 在application.properties或application.yml中配置Flyway

spring:
  flyway:
    enabled: true
    locations: classpath:db/migration

创建迁移脚本: 将 SQL 迁移脚本放置在 src/main/resources/db/migration 目录中。按照 Flyway 的命名约定命名脚本(V1_Initial_Setup.sql、V2_Add_User_Table.sql 等)

-- V1__Initial_Setup.sql
CREATE TABLE user (
    id BIGINT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    email VARCHAR(100) NOT NULL UNIQUE
);

运行迁移: Flyway 将在应用程序启动时自动运行迁移

使用 Liquibase 进行数据库迁移:
Liquibase 是另一个用于管理数据库迁移的强大工具,支持 XML、YAML、JSON 和 SQL 格式。

添加依赖项: 将 Liquibase 依赖项添加到 pom.xml


    org.liquibase
    liquibase-core


配置 Liquibase : 在 application.properties 或 application.yml 中配置 Liquibase

spring:
  liquibase:
    enabled: true
    change-log: classpath:db/changelog/db.changelog-master.yaml

创建 ChangeLog 文件: 在 src/main/resources/db/changelog 中定义数据库更改。创建一个包含其他变更日志文件的主变更日志文件 (db.changelog-master.yaml)

databaseChangeLog:
  - changeSet:
      id: 1
      author: yourname
      changes:
        - createTable:
            tableName: user
            columns:
              - column:
                  name: id
                  type: BIGINT
                  autoIncrement: true
                  constraints:
                    primaryKey: true
              - column:
                  name: name
                  type: VARCHAR(100)
                  constraints:
                    nullable: false
              - column:
                  name: email
                  type: VARCHAR(100)
                  constraints:
                    nullable: false
                    unique: true

运行迁移: Liquibase 将在应用程序启动时自动运行迁移

结论
得益于 Spring Data JPA,数据库与 Spring Boot 的集成是无缝的,而 Flyway 和 Liquibase 等工具使管理数据库迁移变得简单。通过遵循本博客中概述的最佳实践,您可以确保您的 Spring Boot 应用程序与 MySQL 等关系数据库高效交互,并且您的数据库模式随着应用程序的增长而顺利发展

版本声明 本文转载于:https://dev.to/abhishek999/database-integration-with-spring-boot-best-practices-and-tools-5doh?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • Spark DataFrame添加常量列的妙招
    Spark DataFrame添加常量列的妙招
    在Spark Dataframe ,将常数列添加到Spark DataFrame,该列具有适用于所有行的任意值的Spark DataFrame,可以通过多种方式实现。使用文字值(SPARK 1.3)在尝试提供直接值时,用于此问题时,旨在为此目的的column方法可能会导致错误。 df.withco...
    编程 发布于2025-05-05
  • 在GO中构造SQL查询时,如何安全地加入文本和值?
    在GO中构造SQL查询时,如何安全地加入文本和值?
    在go中构造文本sql查询时,在go sql queries 中,在使用conting and contement和contement consem per时,尤其是在使用integer per当per当per时,per per per当per. [&​​&&&&&&&&&&&&&&&默元组方法在...
    编程 发布于2025-05-05
  • 如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    如何将MySQL数据库添加到Visual Studio 2012中的数据源对话框中?
    在Visual Studio 2012 尽管已安装了MySQL Connector v.6.5.4,但无法将MySQL数据库添加到实体框架的“ DataSource对话框”中。为了解决这一问题,至关重要的是要了解MySQL连接器v.6.5.5及以后的6.6.x版本将提供MySQL的官方Visual...
    编程 发布于2025-05-05
  • 人脸检测失败原因及解决方案:Error -215
    人脸检测失败原因及解决方案:Error -215
    错误处理:解决“ error:((-215)!empty()in Function Multultiscale中的“ openCV 要解决此问题,必须确保提供给HAAR CASCADE XML文件的路径有效。在提供的代码片段中,级联分类器装有硬编码路径,这可能对您的系统不准确。相反,OPENCV提...
    编程 发布于2025-05-05
  • 为什么在我的Linux服务器上安装Archive_Zip后,我找不到“ class \” class \'ziparchive \'错误?
    为什么在我的Linux服务器上安装Archive_Zip后,我找不到“ class \” class \'ziparchive \'错误?
    class'ziparchive'在Linux Server上安装Archive_zip时找不到错误 commant in lin ins in cland ins in lin.11 on a lin.1 in a lin.11错误:致命错误:在... cass中找不到类z...
    编程 发布于2025-05-05
  • Go web应用何时关闭数据库连接?
    Go web应用何时关闭数据库连接?
    在GO Web Applications中管理数据库连接很少,考虑以下简化的web应用程序代码:出现的问题:何时应在DB连接上调用Close()方法?,该特定方案将自动关闭程序时,该程序将在EXITS EXITS EXITS出现时自动关闭。但是,其他考虑因素可能保证手动处理。选项1:隐式关闭终止数...
    编程 发布于2025-05-05
  • 版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    在时间戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源于遗留实现的关注,这些限制需要对当前的_timestamp功能进行特定的实现。 创建表`foo`( `Productid` int(10)unsigned not n...
    编程 发布于2025-05-05
  • Python高效去除文本中HTML标签方法
    Python高效去除文本中HTML标签方法
    在Python中剥离HTML标签,以获取原始的文本表示 仅通过Python的MlStripper 来简化剥离过程,Python Standard库提供了一个专门的功能,MLSTREPERE,MLSTREPERIPLE,MLSTREPERE,MLSTREPERIPE,MLSTREPERCE,MLST...
    编程 发布于2025-05-05
  • 如何使用Python的请求和假用户代理绕过网站块?
    如何使用Python的请求和假用户代理绕过网站块?
    如何使用Python的请求模拟浏览器行为,以及伪造的用户代理提供了一个用户 - 代理标头一个有效方法是提供有效的用户式header,以提供有效的用户 - 设置,该标题可以通过browser和Acterner Systems the equestersystermery和操作系统。通过模仿像Chro...
    编程 发布于2025-05-05
  • 在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    mysql-python安装错误:“ mysql_config找不到”“ 由于缺少MySQL开发库而出现此错误。解决此问题,建议在Ubuntu上使用该分发的存储库。使用以下命令安装Python-MysqldB: sudo apt-get安装python-mysqldb sudo pip in...
    编程 发布于2025-05-05
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-05-05
  • 编译器报错“usr/bin/ld: cannot find -l”解决方法
    编译器报错“usr/bin/ld: cannot find -l”解决方法
    错误:“ usr/bin/ld:找不到-l “ 此错误表明链接器在链接您的可执行文件时无法找到指定的库。为了解决此问题,我们将深入研究如何指定库路径并将链接引导到正确位置的详细信息。添加库搜索路径的一个可能的原因是,此错误是您的makefile中缺少库搜索路径。要解决它,您可以在链接器命令中添加...
    编程 发布于2025-05-05
  • 如何在Chrome中居中选择框文本?
    如何在Chrome中居中选择框文本?
    选择框的文本对齐:局部chrome-inly-ly-ly-lyly solument 您可能希望将文本中心集中在选择框中,以获取优化的原因或提高可访问性。但是,在CSS中的选择元素中手动添加一个文本 - 对属性可能无法正常工作。初始尝试 state)</option> < op...
    编程 发布于2025-05-05
  • eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    称量()和ast.literal_eval()中的Python Security 在使用用户输入时,必须优先确保安全性。强大的Python功能Eval()通常是作为潜在解决方案而出现的,但担心其潜在风险。本文深入研究了eval()和ast.literal_eval()之间的差异,突出显示其安全性含义...
    编程 发布于2025-05-05
  • Python读取CSV文件UnicodeDecodeError终极解决方法
    Python读取CSV文件UnicodeDecodeError终极解决方法
    在试图使用已内置的CSV模块读取Python中时,CSV文件中的Unicode Decode Decode Decode Decode decode Error读取,您可能会遇到错误的错误:无法解码字节 在位置2-3中:截断\ uxxxxxxxx逃脱当CSV文件包含特殊字符或Unicode的路径逃...
    编程 发布于2025-05-05

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3