」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 資料庫與 Spring Boot 整合:最佳實踐和工具

資料庫與 Spring Boot 整合:最佳實踐和工具

發佈於2024-07-30
瀏覽:497

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]刪除
最新教學 更多>
  • 如何使用char_length()在mySQL中按字符串長度對數據進行排序?
    如何使用char_length()在mySQL中按字符串長度對數據進行排序?
    [2使用內置的char_length()function。 char_length()和length() 此查詢將從指定的表中檢索所有行,並基於上升順序對它們進行排序指定列的字符長度。帶有更長字符串的行將出現在結果的底部。
    程式設計 發佈於2025-02-06
  • 如何使用Python的記錄模塊實現自定義處理?
    如何使用Python的記錄模塊實現自定義處理?
    使用Python的Loggging Module 確保正確處理和登錄對於疑慮和維護的穩定性至關重要Python應用程序。儘管手動捕獲和記錄異常是一種可行的方法,但它可能乏味且容易出錯。 解決此問題,Python允許您覆蓋默認的異常處理機制,並將其重定向為登錄模塊。這提供了一種方便而係統的方法來捕獲...
    程式設計 發佈於2025-02-06
  • 哪種哈希算法最適合PHP中的安全密碼存儲?
    哪種哈希算法最適合PHP中的安全密碼存儲?
    安全密碼存儲:SHA1 vs MD5 VS SHA256 vs bcrypt bcrypt:首選選擇 通過password_hash()函數: //創建哈希 $ hash = password_hash($ password,password_default,['cost'=> ...
    程式設計 發佈於2025-02-06
  • 如何使用不同數量列的聯合數據庫表?
    如何使用不同數量列的聯合數據庫表?
    合併列數不同的表 當嘗試合併列數不同的數據庫表時,可能會遇到挑戰。一種直接的方法是在列數較少的表中,為缺失的列追加空值。 例如,考慮兩個表,表 A 和表 B,其中表 A 的列數多於表 B。為了合併這些表,同時處理表 B 中缺失的列,請按照以下步驟操作: 確定表 B 中缺失的列,並將它們添加到表的...
    程式設計 發佈於2025-02-06
  • 如何使用shell_exec()從php執行mySQL *.sql文件?
    如何使用shell_exec()從php執行mySQL *.sql文件?
    在PHP 中執行mysql *.sql文件時,在創建網站數據庫時,您可能會遇到需要執行的方案。 SQL文件從PHP到自動化站點生成。雖然zend_framework可能是有益的,但由於SQL語句中的不一致而直接運行。推薦的方法是使用Shell_exec()調用MySQL工具以執行您的 *.sql腳...
    程式設計 發佈於2025-02-06
  • 為什麼C#沒有用於IEnumerable的for Extension方法?
    為什麼C#沒有用於IEnumerable的for Extension方法?
    [2 [2 最近關於C#缺乏擴展方法的擴展方法] 界面? 有趣的是,只有 list 包括此功能。 [2 這是遺漏的性能優化嗎?還是有更深的根本原因? 幾種理論試圖解釋這一明顯的差距。 [2 一個觀點表明,C#的內置 [2 { item.dosomething(); } 這與擴展...
    程式設計 發佈於2025-02-06
  • 對象擬合:IE和Edge中的封面失敗,如何修復?
    對象擬合:IE和Edge中的封面失敗,如何修復?
    解決此問題,我們採用了一個巧妙的CSS解決方案來解決問題:高度:100%; 高度:auto ; 寬度:100%; //對於水平塊 ,使用絕對定位將圖像定位在中心,以object-fit:object-fit :cover in IE和edge消除了問題。現在,圖像將按比例擴展,保持所需的效果而不...
    程式設計 發佈於2025-02-06
  • 如何將LINQ的聚合方法用於有效的字符串串聯?
    如何將LINQ的聚合方法用於有效的字符串串聯?
    與linq 的傳統方法涉及使用stringBuilder並在循環中附加每個字符串。但是,對於更有效的方法,LINQ提供了聚合查詢。 一個匯總查詢是一個函數,該函數獲取值集合併返回標量值。使用點通用,您可以在iEnumerable對像上調用聚合查詢。 與LINQ concateNate strin...
    程式設計 發佈於2025-02-06
  • PHP中整數的最大值是多少?
    PHP中整數的最大值是多少?
    在php中揭示了int值的限制:探索php_int_max 在PHP 未簽名的整數和php 確定整數大小和最大值 64位平台和int values 在摘要中,而PHP中的特定int值範圍取決於平台,典型的最大值大約為通常遇到20億。在與整數合作以確保准確的計算和有效的代碼執行時,了解這些限制至關重...
    程式設計 發佈於2025-02-06
  • 如何在整個HTML文檔中設計特定元素類型的第一個實例?
    如何在整個HTML文檔中設計特定元素類型的第一個實例?
    [2單獨使用CSS,整個HTML文檔可能是一個挑戰。 the:第一型偽級僅限於與其父元素中類型的第一個元素匹配。 以下CSS將使用添加的類樣式的第一個段落: }
    程式設計 發佈於2025-02-06
  • 在沒有密碼提示的情況下,如何在Ubuntu上安裝MySQL?
    在沒有密碼提示的情況下,如何在Ubuntu上安裝MySQL?
    在ubuntu 使用debconf-set-selections sudo debconf-set-selections
    程式設計 發佈於2025-02-06
  • 如何在Python中生成具有小數步驟值的範圍?
    如何在Python中生成具有小數步驟值的範圍?
    在range()要克服此限制,建議將步驟值指定為在範圍內生成的點數。 Numpy庫提供了linspace函數,該功能需要多個點和可選的終點值。例如: np.linspace(0,1,10,endpoint = false)#返回[0,0.1,0.2,...,0.9] 如果使用浮點數步驟值,則Num...
    程式設計 發佈於2025-02-06
  • 哪種方法更有效地用於點 - 填點檢測:射線跟踪或matplotlib \的路徑contains_points?
    哪種方法更有效地用於點 - 填點檢測:射線跟踪或matplotlib \的路徑contains_points?
    在Python 射線tracing方法Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a路徑對象表示多邊形。它檢查給定點是否位於定義路徑內。 T...
    程式設計 發佈於2025-02-06
  • 可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    可以在純CS中將多個粘性元素彼此堆疊在一起嗎?
    </main> <section> ,但无法使其正常工作,如您所见。任何洞察力都将不胜感激! display:grid; { position:sticky; top:1em; z-index:1 1 ; { { { pos...
    程式設計 發佈於2025-02-06
  • 為什麼在C#中不支持抽象靜態方法?
    為什麼在C#中不支持抽象靜態方法?
    在C#靜態方法:更深層的外觀靜態方法與實例方法不同,因為它們不需要它們。將訪問的對象實例化。它們是通過班級名稱而不是通過對象引用來調用的。為靜態方法調用生成的中間語言(IL)代碼直接名稱定義該方法的類,無論調用類別如何。 args) { b.test(); } ...
    程式設計 發佈於2025-02-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3