搜尋
首頁Javajava教程Spring Boot 入門或 .NET 開發人員部分在 Spring Boot 中建立產品實體 CRUD 應用程式

Getting Started with Spring Boot or .NET Developers Part Building a Product Entity CRUD Application in Spring Boot

在上一篇文章中探索了Spring Boot 3 的基礎知識後,讓我們透過實作Product 實體CRUD(創建、讀取、更新、刪除)操作來更深入地了解。在此過程中,我們將比較核心 Spring Boot 概念與 .NET Core 對應概念,以幫助彌合 .NET 開發人員過渡到 Java 生態系統的差距。

設定項目

開始之前,請確保您已準備好一個具有以下相依性的 Spring Boot 專案:

  • Spring Web:用於建立 REST API。
  • Spring Data JPA:用於資料庫互動。
  • PostgreSQL 驅動程式:用於連接到 PostgreSQL 資料庫。

使用 Docker 在本地運行 PostgreSQL

要在本地運行 PostgreSQL,請使用 Docker 快速設定實例:

  1. 拉取 PostgreSQL 鏡像:

    docker pull postgres
    
  2. 運行 PostgreSQL 容器:

    docker run --name postgres-db -e POSTGRES_PASSWORD=yourpassword -e POSTGRES_USER=yourusername -e POSTGRES_DB=mydatabase -p 5432:5432 -d postgres
    

    將您的使用者名稱、您的密碼和 mydatabase 替換為您想要的使用者名稱、密碼和資料庫名稱。

  3. 驗證資料庫正在運作:

    docker ps
    
  4. 使用資料庫用戶端(例如 DBeaver、pgAdmin 或 psql)連接到 localhost:5432 並驗證您的資料庫是否可存取。

更新 pom.xml 檔案

如果您使用 Maven,請在 pom.xml 檔案中包含以下依賴項,以確保所有必需的程式庫可用:

<dependencies>
    <dependency>
        <groupid>org.springframework.boot</groupid>
        <artifactid>spring-boot-starter-web</artifactid>
    </dependency>
    <dependency>
        <groupid>org.springframework.boot</groupid>
        <artifactid>spring-boot-starter-data-jpa</artifactid>
    </dependency>
    <dependency>
        <groupid>org.postgresql</groupid>
        <artifactid>postgresql</artifactid>
        <version>42.5.0</version>
    </dependency>
    <dependency>
        <groupid>org.springframework.boot</groupid>
        <artifactid>spring-boot-starter-test</artifactid>
        <scope>test</scope>
    </dependency>
</dependencies>

此外,確保包含以下外掛程式來建置專案:

<build>
    <plugins>
        <plugin>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-maven-plugin</artifactid>
        </plugin>
    </plugins>
</build>

與 .NET Core 的比較
在 .NET Core 中,套件參考是使用 csproj 檔案管理的。 PostgreSQL 支援的 Web API 的等效相依性可能如下所示:

<itemgroup>
  <packagereference include="Microsoft.AspNetCore.App"></packagereference>
  <packagereference include="Npgsql.EntityFrameworkCore.PostgreSQL" version="6.0.0"></packagereference>
</itemgroup>

設定 PostgreSQL 資料庫

更新您的 application.yml 檔案以連接到 PostgreSQL 資料庫:

spring:
  datasource:
    url: jdbc:postgresql://localhost:5432/mydatabase
    username: yourusername
    password: yourpassword
  jpa:
    properties:
      hibernate:
        dialect: org.hibernate.dialect.PostgreSQLDialect
    hibernate:
      ddl-auto: update

將 mydatabase、yourusername 和 yourpassword 替換為您的實際 PostgreSQL 資料庫詳細資訊。 ddl-auto=update 設定確保 Hibernate 根據您的實體定義自動建立或更新表。

與 .NET Core 的比較
在 .NET Core 中,類似的配置將駐留在 appsettings.json 中:

{
  "ConnectionStrings": {
    "DefaultConnection": "Host=localhost;Database=mydatabase;Username=yourusername;Password=yourpassword"
  },
  "EntityFramework": {
    "MigrationsAssembly": "YourProjectName"
  }
}

專案結構概述

Spring Boot 專案將程式碼組織到套件中:

  • 實體:包含資料模型。
  • repository:資料庫操作的介面。
  • 控制器:REST端點。
  • 服務(可選):業務邏輯。

此結構類似 .NET Core 專案中的典型層:模型、資料/儲存庫、控制器和服務。

第 1 步:定義產品實體

在 Spring Boot 中,實體代表資料庫表,類似 Entity Framework Core 中的模型。使用 @Entity 和 @Id 等註解將類別對應到表:

docker pull postgres

.NET Core 等效項

docker run --name postgres-db -e POSTGRES_PASSWORD=yourpassword -e POSTGRES_USER=yourusername -e POSTGRES_DB=mydatabase -p 5432:5432 -d postgres

第 2 步:建立儲存庫

在 Spring Boot 中,儲存庫是擴充 JpaRepository 的介面。它們提供內建的 CRUD 操作,類似於 EF Core 中的 DbContext。

docker ps

.NET Core 等效項

<dependencies>
    <dependency>
        <groupid>org.springframework.boot</groupid>
        <artifactid>spring-boot-starter-web</artifactid>
    </dependency>
    <dependency>
        <groupid>org.springframework.boot</groupid>
        <artifactid>spring-boot-starter-data-jpa</artifactid>
    </dependency>
    <dependency>
        <groupid>org.postgresql</groupid>
        <artifactid>postgresql</artifactid>
        <version>42.5.0</version>
    </dependency>
    <dependency>
        <groupid>org.springframework.boot</groupid>
        <artifactid>spring-boot-starter-test</artifactid>
        <scope>test</scope>
    </dependency>
</dependencies>

第 3 步:實作服務層(選用)

服務層處理業務邏輯。雖然是可選的,但對於大型應用程式來說這是一個很好的做法。

<build>
    <plugins>
        <plugin>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-maven-plugin</artifactid>
        </plugin>
    </plugins>
</build>

.NET Core 等效項

<itemgroup>
  <packagereference include="Microsoft.AspNetCore.App"></packagereference>
  <packagereference include="Npgsql.EntityFrameworkCore.PostgreSQL" version="6.0.0"></packagereference>
</itemgroup>

第 4 步:建構控制器

控制器處理 HTTP 請求,就像在 ASP.NET Core 中一樣。

spring:
  datasource:
    url: jdbc:postgresql://localhost:5432/mydatabase
    username: yourusername
    password: yourpassword
  jpa:
    properties:
      hibernate:
        dialect: org.hibernate.dialect.PostgreSQLDialect
    hibernate:
      ddl-auto: update

.NET Core 等效項

{
  "ConnectionStrings": {
    "DefaultConnection": "Host=localhost;Database=mydatabase;Username=yourusername;Password=yourpassword"
  },
  "EntityFramework": {
    "MigrationsAssembly": "YourProjectName"
  }
}

第 5 步:測試您的 API

運行您的應用程式並使用 Postman 或 cURL 等工具測試端點。確保您的 PostgreSQL 資料庫正在運作並正確配置。

應用程式啟動並執行後,使用 Postman 或 cURL 測試 CRUD 端點。確保 PostgreSQL 正在運作並正確配置。

使用 Postman 測試端點

  • GET /api/products:取得所有產品。
  • GET /api/products/{id}:透過 ID 取得單一產品。
  • POST /api/products:建立一個新產品。
  • DELETE /api/products/{id}:透過 ID 刪除產品。

主要比較

Feature Spring Boot 3 .NET Core
Dependency Injection Built-in with @Autowired or constructor injection Built-in with AddScoped, AddSingleton
ORM Tool Spring Data JPA Entity Framework Core
Routing @RequestMapping, @GetMapping [Route], [HttpGet]
Middleware Spring Interceptors ASP.NET Middleware
Response Handling ResponseEntity IActionResult

結論

在 Spring Boot 中建立 CRUD 應用程式很簡單,特別是對於熟悉 .NET Core 的人來說。依賴注入、ORM 和 RESTful API 的原理在兩個生態系中都很相似。本指南只是一個開始 - 未來的貼文將涵蓋 Lombok 整合、Swagger/OpenAPI、驗證、錯誤處理和資料庫遷移。敬請期待!

編碼愉快!


參考文獻

  1. Spring Boot 文件:https://spring.io/projects/spring-boot
  2. PostgreSQL 文件:https://www.postgresql.org/docs/
  3. Spring Data JPA 文件:https://spring.io/projects/spring-data-jpa
  4. .NET Core 文件:https://docs.microsoft.com/en-us/aspnet/core/?view=aspnetcore-7.0

以上是Spring Boot 入門或 .NET 開發人員部分在 Spring Boot 中建立產品實體 CRUD 應用程式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
2025年的前4個JavaScript框架:React,Angular,Vue,Svelte2025年的前4個JavaScript框架:React,Angular,Vue,SvelteMar 07, 2025 pm 06:09 PM

本文分析了2025年的前四個JavaScript框架(React,Angular,Vue,Susve),比較了它們的性能,可伸縮性和未來前景。 儘管由於強大的社區和生態系統,所有這些都保持占主導地位,但它們的相對人口

如何使用咖啡因或Guava Cache等庫在Java應用程序中實現多層緩存?如何使用咖啡因或Guava Cache等庫在Java應用程序中實現多層緩存?Mar 17, 2025 pm 05:44 PM

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

Java的類負載機制如何起作用,包括不同的類載荷及其委託模型?Java的類負載機制如何起作用,包括不同的類載荷及其委託模型?Mar 17, 2025 pm 05:35 PM

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA

Node.js 20:關鍵性能提升和新功能Node.js 20:關鍵性能提升和新功能Mar 07, 2025 pm 06:12 PM

Node.js 20通過V8發動機改進可顯著提高性能,特別是更快的垃圾收集和I/O。 新功能包括更好的WebSembly支持和精製的調試工具,提高開發人員的生產率和應用速度。

冰山:數據湖桌的未來冰山:數據湖桌的未來Mar 07, 2025 pm 06:31 PM

冰山是用於大型分析數據集的開放式桌子格式,可提高數據湖的性能和可伸縮性。 它通過內部元數據管理解決了鑲木quet/orc的局限

Spring Boot Snakeyaml 2.0 CVE-2022-1471問題已修復Spring Boot Snakeyaml 2.0 CVE-2022-1471問題已修復Mar 07, 2025 pm 05:52 PM

本文介紹了SnakeyAml中的CVE-2022-1471漏洞,這是一個允許遠程代碼執行的關鍵缺陷。 它詳細介紹瞭如何升級春季啟動應用程序到Snakeyaml 1.33或更高版本的降低風險,強調了依賴性更新

如何將JPA(Java持久性API)用於具有高級功能(例如緩存和懶惰加載)的對象相關映射?如何將JPA(Java持久性API)用於具有高級功能(例如緩存和懶惰加載)的對象相關映射?Mar 17, 2025 pm 05:43 PM

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

如何將Maven或Gradle用於高級Java項目管理,構建自動化和依賴性解決方案?如何將Maven或Gradle用於高級Java項目管理,構建自動化和依賴性解決方案?Mar 17, 2025 pm 05:46 PM

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。