인프런 커뮤니티 질문&답변
원하는 칼럼만 함께 조회하고 싶을 때
작성
·
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로 조회하시면 됩니다.
역시 공부하고 뭘 하나 적용해보아야 완전히 본인 것이 되는데 잘 하고 계시네요 ㅎㅎ
화이팅!
감사합니다.





