JHipster는 Java 웹 애플리케이션 개발을 위한 도구입니다. 이 글에서는 JHipster를 사용하여 데이터베이스와의 연동을 설정하는 방법을 알아보겠습니다.
1. 데이터베이스 종류 선택
JHipster는 다양한 데이터베이스를 지원합니다. JHipster CLI를 사용하여 프로젝트를 생성할 때 데이터베이스를 선택할 수 있습니다. 다음은 JHipster에서 지원하는 몇 가지 데이터베이스 종류입니다.
- MySQL
- PostgreSQL
- Oracle
- H2 (개발용 임베디드 데이터베이스)
2. 데이터베이스 설정
프로젝트를 생성하면 src/main/resources/config
디렉토리에 application.yml
파일이 생성됩니다. 이 파일을 열고 아래와 같이 데이터베이스 연결 정보를 설정합니다.
spring:
datasource:
url: "jdbc:mysql://localhost:3306/mydatabase"
username: "username"
password: "password"
driver-class-name: "com.mysql.jdbc.Driver"
위 예시는 MySQL 데이터베이스에 연결하기 위한 설정이며, url
, username
, password
, driver-class-name
을 해당 데이터베이스에 맞게 수정해야 합니다.
3. 데이터베이스 마이그레이션
JHipster는 Liquibase를 사용하여 데이터베이스 스키마 관리를 지원합니다. 데이터베이스 스키마를 변경하면 해당 변경 사항을 적용하기 위해 마이그레이션 스크립트를 실행해야 합니다.
./mvnw liquibase:update
위 명령을 실행하면 Liquibase가 마이그레이션 스크립트를 실행하여 데이터베이스를 업데이트합니다.
4. JPA 엔티티 생성
JHipster에서는 JPA(Java Persistence API)를 사용하여 데이터베이스와의 연동을 처리합니다. 엔티티 클래스를 생성하고 필요한 필드와 매핑을 설정합니다.
import javax.persistence.*;
@Entity
@Table(name = "my_table")
public class MyEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "name")
private String name;
// getters and setters
}
위 예시는 my_table
테이블과 매핑되는 MyEntity
클래스입니다. 필요한 필드와 매핑 어노테이션을 추가한 뒤, JPA가 테이블과 매핑하여 데이터베이스와 상호작용할 수 있습니다.
5. 데이터베이스 사용
이제 데이터베이스와의 연동이 설정되었으므로 다음과 같이 데이터베이스에 접근하여 작업할 수 있습니다.
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class MyService {
@Autowired
private MyEntityRepository repository;
public List<MyEntity> getAllEntities() {
return repository.findAll();
}
// 기타 필요한 메서드
}
위 예시는 MyEntity
엔티티에 접근하기 위한 MyService
서비스 클래스입니다. MyEntityRepository
인터페이스를 사용하여 데이터베이스에 대한 CRUD(Create, Read, Update, Delete) 작업을 수행할 수 있습니다.
JHipster를 사용하여 데이터베이스와의 연동을 설정하는 방법에 대해 알아보았습니다. JHipster의 강력한 기능을 사용하여 웹 애플리케이션을 개발할 때 데이터베이스의 활용도를 높일 수 있습니다.