Engineering Note

[JPA] @Enumerated 어노테이션 본문

Server/JPA ORM

[JPA] @Enumerated 어노테이션

Software Engineer Kim 2025. 9. 14. 09:41

@Enumerated 

- JPA에서 Enum 타입을 DB에 어떤 방식으로 저장할 지 결정하는 어노테이션이다.

 

기본값

@Enumerated(EnumType.ORDINAL)

 

- Enum의 순서 0, 1, 2 로 DB에 저장

 

예시

public enum OrderStatus {
    ORDER, CANCEL
}

 

주문 상태를 나타내는 상수 Enum이 있다고 했을 때DB 저장시 ORDER = 0, CANCEL = 1로 DB에 저장된다.

나중에 Enum에 새로운 값이 추가되면 DB의 값이 꼬이는 문제가 발생한다.

 

public enum OrderStatus {
    ORDER, SHIPPED, CANCEL
}

 

DB에서 CANCEL이 1로 저장된 값이 있지만, SHIPPED가 추가된 이후에는 SHIPPED가 1이 되어 버린다.

 

이러한 이유 때문에 'EnumType.STRING)을 권장한다.

 

@Enumerated(EnumType.STRING)

- ENUM 이름을 자열로 DB에 저장

- 저장시 ORDER, CANCEL이 문자열로 DB에 저장

- 순서가 바뀌어도 안전하고, DB에서 가독성이 가독성이 좋다.

- 단점으로는 DB의 저장용량을 더 필요로 한다. 문자열이기 때문.

Comments