작성
·
41
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. 전한준님께서 질문해 주신 카테고리 매핑에 대한 설명을 드리겠습니다.
카테고리를 부모로 설정하고 리스트로 관리하는 이유는 계층형 구조를 관리하기 위함입니다. 예를 들어, 쇼핑몰의 카테고리를 생각해보면 “의류”라는 상위 카테고리 아래에 “상의”, “바지” 등의 하위 카테고리가 존재할 수 있습니다. 이러한 구조를 데이터베이스에서 관리하기 위해, @ManyToOne
과 @OneToMany
매핑을 사용해 계층적 관계를 설정합니다.
@ManyToOne
과 @JoinColumn(name="PARENT_ID")
은 현 카테고리의 부모 카테고리를 나타내며, 하나의 부모 카테고리가 여러 자식 카테고리를 가질 수 있기에 다대일 관계가 됩니다.@OneToMany(mappedBy="parent")
는 현 카테고리가 가진 자식 카테고리들의 리스트를 나타내며, 한 카테고리가 여러 자식을 가질 수 있습니다.실무에서는 이러한 계층 구조를 명확히 하기 위해 중간 테이블을 사용하여 연관 관계를 관리하는 경우가 많습니다. 중간 테이블을 사용하면 데이터의 중복을 줄이고, 복잡한 계층 관계를 명확하고 쉽게 관리할 수 있습니다. 또한, @ManyToMany
관계에서도 중간 테이블을 생성하여 여러 개의 엔티티 사이의 관계를 명확히 정의할 수 있습니다.
관련하여 유사한 질문과 답변이 있는 게시물을 공유드립니다:
위의 답변들을 통해 부모-자식 관계와 중간 테이블의 필요성에 대해 좀 더 깊은 이해가 가능할 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.