강의

멘토링

로드맵

인프런 커뮤니티 질문&답변

고관우님의 프로필 이미지
고관우

작성한 질문수

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

간단한 주문 조회 V4: JPA에서 DTO로 바로 조회

연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략

작성

·

19

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
강의를 들으면서 웬만하면 repository 에서 entity 를 받아와서 이걸 Dto 로 변환해서 반환하게끔 처리하는 것을 배웠습니다.

다만 실무에서 연관관계 매핑을 쓰지 않을 경우 어떤 전략을 취해야 하는지 모르겠어서 질문드립니다.

단일 entity 만을 반환하는 경우 크게 문제되지 않지만, join 을 하게될 경우 entity 가 2개 이상이 필요한데 이 경우 Dto 를 쓸 수밖에 없는 상황이라고 생각됩니다.
(혹은 querydsl 에서 Tuple 을 쓸 수 있다고 생각합니다)

 

이런 경우 어떻게 repository 에서 service 로 데이터를 올려주나요?

답변 2

0

안녕하세요. 고관우님, 공식 서포터즈 y2gcoder입니다.

말씀하신 경우도 큰 틀에서 보면 강의에서 제공드리는 가이드와 다르지 않습니다! 엔티티 를 기본적으로 조회하되, 엔티티(+지연로딩)으로 해결되지 않는 요구사항에 대해서는 DTO로 바로 조회하도록 구성하시는 것을 추천합니다 🙂

감사합니다.

0

안녕하세요, 인프런 AI 인턴입니다. 고관우님.

연관관계 매핑 없이 데이터를 효과적으로 처리하는 방법에 대해 질문해 주셨군요. 실무에서는 여러 상황에 따라 적절한 전략을 취하는 것이 중요합니다.

1. DTO 사용

연관관계 매핑을 사용하지 않을 경우, DTO(Data Transfer Object)를 많이 활용합니다. DTO는 데이터 전송을 위한 객체로, 복잡한 연관 관계를 피하면서 필요한 데이터만을 선택하여 네트워크 비용을 줄일 수 있습니다. 예를 들어, 두 개 이상의 엔티티를 조인하여 데이터를 조합할 경우, 특정 조회 쿼리를 통해 필요한 필드만을 가져와 DTO에 매핑하는 것이 좋습니다.

2. Querydsl과 Tuple 사용

Querydsl을 사용하면 type-safe한 쿼리를 작성할 수 있습니다. 이 과정에서 Tuple을 사용하면 다양한 데이터 값을 쉽게 조합할 수 있습니다. Tuple을 통해 여러 개의 엔티티에서 필요한 데이터만 선별하여 가져오고, 이를 다시 DTO에 매핑하여 전달하는 방식으로 유연하게 대응할 수 있습니다.

3. Custom Repository Implementation

더 복잡한 쿼리가 필요한 경우에는 JPA Repository를 상속받은 Custom Repository를 구현할 수 있습니다. 직접 JPQL이나 Querydsl을 통해 맞춤형 쿼리를 작성하고, 여기에 DTO를 반환 타입으로 설정하여 비즈니스 로직을 간결하게 유지할 수 있습니다.

이러한 방식들은 조합하여 성능 최적화 및 유지보수를 용이하게 하는 데 큰 도움이 될 수 있습니다.

관련된 논의는 “데이터 조회에 대해서 질문드립니다.”에서 유용한 정보를 찾아볼 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

고관우님의 프로필 이미지
고관우

작성한 질문수

질문하기