찾다
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(Create, Read, Update, Delete) 작업을 구현하여 더 자세히 살펴보겠습니다. 그 과정에서 핵심 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
    

    yourusername, yourpassword 및 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 지원 웹 API에 대한 동등한 종속성은 다음과 같습니다.

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

PostgreSQL 데이터베이스 구성

PostgreSQL 데이터베이스에 연결하려면 application.yml 파일을 업데이트하세요.

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 프로젝트는 코드를 패키지로 구성합니다.

  • 엔티티: 데이터 모델을 포함합니다.
  • 저장소: 데이터베이스 작업을 위한 인터페이스
  • 컨트롤러: 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를 확장하는 인터페이스입니다. EF Core의 DbContext와 유사한 내장 CRUD 작업을 제공합니다.

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단계: 컨트롤러 구축

컨트롤러는 ASP.NET Core에서와 마찬가지로 HTTP 요청을 처리합니다.

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. 스프링 부트 문서: https://spring.io/projects/spring-boot
  2. PostgreSQL 문서: https://www.postgresql.org/docs/
  3. Spring 데이터 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으로 문의하세요.
JVM 성능 대 기타 언어JVM 성능 대 기타 언어May 14, 2025 am 12:16 AM

JVM 'sperformanceIscompetitive, ontotherRuntimes, 안전 및 생산성을 제공합니다

Java 플랫폼 독립성 : 사용의 예Java 플랫폼 독립성 : 사용의 예May 14, 2025 am 12:14 AM

javaachievesplatformincendenceThermeThoughthejavavirtualMachine (JVM), codeiscompiledintobytecode, notmachine-specificcode.2) bytecodeistredbythejvm, anblingcross- shoughtshoughts

JVM 아키텍처 : Java Virtual Machine에 대한 깊은 다이빙JVM 아키텍처 : Java Virtual Machine에 대한 깊은 다이빙May 14, 2025 am 12:12 AM

thejvmisanabstractcomputingmachinecrucialforrunningjavaprogramsduetoitsplatform-independentarchitection.itincludes : 1) classloaderforloadingclasses, 2) runtimeDataAreaFordatorage, 3) executionEnginewithgringreter, jitcompiler 및 ggarocubucbugecutec

JVM : JVM은 OS와 관련이 있습니까?JVM : JVM은 OS와 관련이 있습니까?May 14, 2025 am 12:11 AM

Theosasittranslatesjavabytecodeintomachine-specificinstructions, ManagesMemory 및 HandlesgarbageCollection의 Jvmhasacloserelationship

Java : 한 번 쓰기, 어디서나 달리기 (Wora) - 플랫폼 독립에 대한 깊은 다이빙Java : 한 번 쓰기, 어디서나 달리기 (Wora) - 플랫폼 독립에 대한 깊은 다이빙May 14, 2025 am 12:05 AM

Java 구현 "Write Once, Run Everywhere"는 바이트 코드로 컴파일되어 JVM (Java Virtual Machine)에서 실행됩니다. 1) Java 코드를 작성하여 바이트 코드로 컴파일하십시오. 2) 바이트 코드는 JVM이 설치된 모든 플랫폼에서 실행됩니다. 3) JNI (Java Native Interface)를 사용하여 플랫폼 별 기능을 처리하십시오. JVM 일관성 및 플랫폼 별 라이브러리 사용과 같은 과제에도 불구하고 Wora는 개발 효율성 및 배포 유연성을 크게 향상시킵니다.

Java 플랫폼 독립성 : 다른 OS와의 호환성Java 플랫폼 독립성 : 다른 OS와의 호환성May 13, 2025 am 12:11 AM

javaachievesplatformincendenceThoughthehoughthejavavirtualmachine (JVM), hittoutModification.thejvmcompileSjavacodeIntOplatform-independentByTecode, whatitTengretsAndexeSontheSpecoS, toplacetSonthecificos, toacketSecificos

Java가 여전히 강력하게 만드는 기능Java가 여전히 강력하게 만드는 기능May 13, 2025 am 12:05 AM

javaispowerfuldueToitsplatformincendence, 객체 지향적, RichandardLibrary, PerformanceCapabilities 및 StrongSecurityFeatures.1) Platform IndependenceAllowsApplicationStorunannyDevicesUpportingjava.2) 대상 지향적 프로그래밍 프로모션 Modulara

최고 Java 기능 : 개발자를위한 포괄적 인 가이드최고 Java 기능 : 개발자를위한 포괄적 인 가이드May 13, 2025 am 12:04 AM

최고 Java 기능에는 다음이 포함됩니다. 1) 객체 지향 프로그래밍, 다형성 지원, 코드 유연성 및 유지 관리 가능성 향상; 2) 예외 처리 메커니즘, 시도 캐치-패치 블록을 통한 코드 견고성 향상; 3) 쓰레기 수집, 메모리 관리 단순화; 4) 제네릭, 유형 안전 강화; 5) 코드를보다 간결하고 표현력있게 만들기위한 AMBDA 표현 및 기능 프로그래밍; 6) 최적화 된 데이터 구조 및 알고리즘을 제공하는 풍부한 표준 라이브러리.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.