Files
spring-boot-examples/docs/_archive/jpa.md
2025-04-08 19:56:24 +09:00

289 lines
6.9 KiB
Markdown

# Spring Boot의 Model 및 JPA 관련 어노테이션 정리
Spring Boot에서 **모델(Model)과 JPA(Java Persistence API)** 를 활용할 때 사용되는 주요 어노테이션을 표로 정리하고, 각각에 대한 설명과 예제 코드를 제공합니다.
---
## 1. Model 및 JPA 관련 어노테이션 정리표
| 어노테이션 | 설명 |
|------------------------|----------------------------------|
| `@Entity` | JPA 엔티티 클래스임을 명시 |
| `@Table` | 데이터베이스의 테이블과 매핑 |
| `@Id` | 기본 키(PK) 지정 |
| `@GeneratedValue` | 기본 키 값 자동 생성 전략 설정 |
| `@Column` | 데이터베이스 컬럼과 매핑 |
| `@Transient` | 특정 필드를 영속성에서 제외 |
| `@Embedded` | 내장(Embeddable) 타입을 포함 |
| `@Embeddable` | 내장 타입을 정의 |
| `@Enumerated` | Enum 타입을 컬럼에 매핑 |
| `@Lob` | 대용량 데이터(Long Text, Blob) 저장 |
| `@Temporal` | 날짜/시간 타입 매핑 |
| `@ManyToOne` | 다대일 관계 설정 |
| `@OneToMany` | 일대다 관계 설정 |
| `@OneToOne` | 일대일 관계 설정 |
| `@ManyToMany` | 다대다 관계 설정 |
| `@JoinColumn` | 외래 키(FK) 설정 |
| `@JoinTable` | 다대다 관계에서 조인 테이블 설정 |
| `@MappedSuperclass` | 공통 속성을 가지는 부모 클래스 지정 |
| `@Inheritance` | 상속 매핑 전략 설정 |
| `@DiscriminatorColumn`| 상속 엔티티 구분 컬럼 설정 |
| `@NamedQuery` | JPQL로 미리 정의된 쿼리 설정 |
| `@Query` | 사용자 정의 JPQL 쿼리 작성 |
| `@Modifying` | 데이터 수정 JPQL 쿼리 작성 |
| `@Transactional` | 트랜잭션 범위 설정 |
| `@Repository` | 데이터 액세스 계층을 나타냄 |
| `@EnableJpaRepositories` | JPA 리포지토리 활성화 |
---
## 2. Model 및 JPA 관련 어노테이션 설명 및 예제
### 1) `@Entity`
JPA에서 엔티티 클래스를 나타냅니다. 해당 클래스는 데이터베이스 테이블과 매핑됩니다.
#### 예제:
```java
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
}
```
- `User` 클래스가 `users` 테이블과 매핑됩니다.
---
### 2) `@Table`
엔티티와 매핑될 테이블의 이름을 지정합니다.
#### 예제:
```java
@Entity
@Table(name = "user_table")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
}
```
- `User` 엔티티가 `user_table`과 매핑됩니다.
---
### 3) `@Id`
엔티티의 **기본 키(PK)** 를 지정합니다.
#### 예제:
```java
@Entity
public class Product {
@Id
private Long productId;
}
```
- `productId`가 **기본 키**가 됩니다.
---
### 4) `@GeneratedValue`
기본 키를 자동 생성하도록 설정합니다.
#### 예제:
```java
@Entity
public class Order {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
}
```
- `GenerationType.IDENTITY`**AUTO_INCREMENT** 방식으로 기본 키를 생성합니다.
---
### 5) `@Column`
필드를 특정 컬럼과 매핑할 때 사용합니다.
#### 예제:
```java
@Entity
public class Employee {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "emp_name", length = 100, nullable = false)
private String name;
}
```
- `emp_name`이라는 컬럼에 매핑되고, 길이는 100이며, **NULL을 허용하지 않음**.
---
### 6) `@Transient`
해당 필드를 **DB에 저장하지 않도록** 설정합니다.
#### 예제:
```java
@Entity
public class Person {
@Id
private Long id;
@Transient
private int age;
}
```
- `age` 필드는 **DB에 저장되지 않음**.
---
### 7) `@Enumerated`
Enum 타입을 컬럼에 저장할 때 사용합니다.
#### 예제:
```java
@Entity
public class Task {
public enum Status { PENDING, COMPLETED }
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Enumerated(EnumType.STRING)
private Status status;
}
```
- `EnumType.STRING`을 사용하여 `"PENDING"`, `"COMPLETED"` 형태로 저장됩니다.
---
### 8) `@ManyToOne`
**다대일(N:1) 관계**를 정의합니다.
#### 예제:
```java
@Entity
public class Order {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@ManyToOne
@JoinColumn(name = "user_id")
private User user;
}
```
- `Order` 엔티티는 **User와 다대일 관계**.
---
### 9) `@OneToMany`
**일대다(1:N) 관계**를 정의합니다.
#### 예제:
```java
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@OneToMany(mappedBy = "user")
private List<Order> orders;
}
```
- 한 명의 `User`가 여러 개의 `Order`를 가질 수 있음.
---
### 10) `@OneToOne`
**일대일(1:1) 관계**를 정의합니다.
#### 예제:
```java
@Entity
public class Passport {
@Id
private Long id;
@OneToOne
@JoinColumn(name = "user_id")
private User user;
}
```
-`User`는 하나의 `Passport`를 가짐.
---
### 11) `@ManyToMany`
**다대다(N:M) 관계**를 정의합니다.
#### 예제:
```java
@Entity
public class Student {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@ManyToMany
@JoinTable(
name = "student_course",
joinColumns = @JoinColumn(name = "student_id"),
inverseJoinColumns = @JoinColumn(name = "course_id")
)
private List<Course> courses;
}
```
- `Student``Course`는 다대다 관계이며 **중간 테이블(`student_course`)** 을 가짐.
---
### 12) `@Query`
JPQL을 사용하여 **사용자 정의 쿼리**를 작성합니다.
#### 예제:
```java
@Repository
public interface UserRepository extends JpaRepository<User, Long> {
@Query("SELECT u FROM User u WHERE u.name = :name")
List<User> findByName(@Param("name") String name);
}
```
- `name`이 특정 값인 `User`를 조회하는 쿼리.
---
### 13) `@Transactional`
**트랜잭션 범위를 설정**합니다.
#### 예제:
```java
@Service
public class UserService {
@Transactional
public void updateUser(Long id, String name) {
User user = userRepository.findById(id).orElseThrow();
user.setName(name);
}
}
```
- 메서드 실행 중 예외 발생 시 **자동 롤백**.
---
## 3. 정리
Spring Boot에서 **모델과 JPA 관련 어노테이션**을 정리했습니다.
- `@Entity`, `@Table`, `@Id`, `@Column` → 기본 엔티티 정의
- `@ManyToOne`, `@OneToMany`, `@OneToOne`, `@ManyToMany` → 관계 매핑
- `@Query`, `@Transactional` → 데이터 액세스 및 트랜잭션 처리
이제 **Spring Boot + JPA** 개발을 효과적으로 할 수 있습니다!