작성
·
43
0
안녕하세요 영한님. 다대다 연관관계를 공부하고 제 프로젝트에
적용하려다가 오류가 발생해서 질문드립니다.
Product와 Tag를 다대다로 관계시키기 위해 ProductTag테이블을 만들었습니다.
ResponseProduct에 Product를 넣어서 응답으로 보내려 하는데 이렇게 하니 Product->ProductTag->Tag
->ProductTag 이 과정이 무한반복이 일어나고 있습니다.
이것을 어떻게 해결하면 좋을까요?
항상 영상 잘 보고 있습니다. 화이팅 하세요!!
public class ResponseProduct {
private Product product;
private Long categoryId;
}
@Entity
public class Product {
@OneToMany(mappedBy = "product", orphanRemoval = true)
private List<ProductTag> productTags = new ArrayList<>();
}
@Entity
public class ProductTag {
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "product_id")
private Product product;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "tag_id")
private Tag tag;
}
@Entity
public class Tag {
@OneToMany(mappedBy = "tag", orphanRemoval = true)
private List<ProductTag> productTags = new ArrayList<>();
}
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. III님, 질문 주셔서 감사합니다. 다대다 연관관계에서의 순환 참조 문제가 발생하고 있는 것 같습니다. 이는 자바의 객체를 직렬화하여 JSON으로 변환하는 과정 중에 서로를 참조하는 엔티티 객체들이 무한 재귀로 호출되면서 발생합니다.
문제를 해결하기 위한 몇 가지 방법을 소개해 드리겠습니다:
@JsonIgnore
어노테이션 사용: 순환 참조되는 필드에 @JsonIgnore
를 사용하여 특정 필드를 무시하도록 할 수 있습니다. 예를 들어, Product
엔티티 내부의 productTags
필드에 @JsonIgnore
를 사용하면 직렬화할 때 이 필드를 제외시킬 수 있습니다.
DTO 사용: 응답에 필요한 데이터만 담는 별도의 DTO(Data Transfer Object)를 만들어서 순환 참조를 발생시키는 필드를 거르도록 할 수 있습니다. 이렇게 하면 관련 데이터만 전송할 수 있어서 직렬화 문제를 해결할 수 있습니다.
public class ProductResponseDTO {
private Long productId;
private String productName;
private List<TagDTO> tags;
}
public class TagDTO {
private Long id;
private String name;
}
직렬화 라이브러리 설정: Jackson 라이브러리를 사용하고 있다면, @JsonManagedReference
와 @JsonBackReference
를 사용하여 순환 참조 문제를 해결할 수 있습니다. Product
의 productTags
필드에 @JsonManagedReference
를 사용하고, ProductTag
의 product
필드에 @JsonBackReference
를 사용합니다.
Lombok의 @ToString.Exclude
사용: Lombok을 사용하는 경우, 양방향 연관관계 필드에 @ToString.Exclude
를 사용하여 toString()
메소드 호출 시 해당 필드를 제외할 수 있습니다.
이와 관련하여 유사한 해결 방법을 상세히 다룬 게시물들이 있습니다. 참고해 보세요:
- “many to many entity 생성관련 질문”
- “ManyToMany 관계에서 삭제”
질문에 대한 답변이 도움이 되길 바랍니다! 프로젝트에 도움이 되셨으면 좋겠습니다. 추가적인 궁금한 점이 있으시면 말씀해 주세요!
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.