강의

멘토링

커뮤니티

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

이하영님의 프로필 이미지
이하영

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

원하는 칼럼만 함께 조회하고 싶을 때

작성

·

338

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

안녕하세요! 강의에서 배운 내용을 통해 게시판을 만들어보고 있는 중 질문사항이 생겼습니다.

모든 게시글 목록을 보여주는 화면에서
게시글과 연관관계를 맺고 있는 회원의 회원명이 필요해서
게시글과 함께 회원의 회원명을 조회해오고 싶습니다.

1. 이런 경우에 아래와 같이 회원 엔티티 전체를 select 하는 게 아닌 화면에 필요한 회원의 회원명만 조회하는 게 올바른 방법인지 문의드립니다.

public interface BoardRepositoryInterface extends JpaRepository<Board, Long> {

@Query(value = "select b from Board b join fetch b.writer w",
countQuery = "select count(b) from Board b")
Page<Board> findAllWithWriter(Pageable pageable);
}

2. 엔티티 자체가 아닌 원하는 하나의 칼럼만 조회할 경우에는 패치 조인(엔티티)이 아닌 일반 조인(원하는 칼럼)을 사용해야 하는 것인가요?

3. 일반 조인을 사용하는 게 맞다면 패치 조인과 다르게 1+N 문제를 해결하지 못하는데 이 부분은 어떻게 해결해야 하는지 문의드립니다!

답변 1

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 하영님

이 부분은 성능을 어느정도 까지 최적화 할지에 따라서 달라집니다.

성능이 크게 중요하지 않으면 fetch join만 사용하셔도 충분합니다.

성능이 너무 중요하면 활용2편에서 소개드린 것 처럼 원하는 엔티티를 조인 한 다음에 원하는 필드만 찍어서 DTO로 조회하시면 됩니다.

역시 공부하고 뭘 하나 적용해보아야 완전히 본인 것이 되는데 잘 하고 계시네요 ㅎㅎ

화이팅!

감사합니다.

이하영님의 프로필 이미지
이하영

작성한 질문수

질문하기