2025-04-08T19:56:24
This commit is contained in:
289
docs/_archive/jpa.md
Normal file
289
docs/_archive/jpa.md
Normal file
@@ -0,0 +1,289 @@
|
||||
# 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** 개발을 효과적으로 할 수 있습니다!
|
||||
Reference in New Issue
Block a user