inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

강의 소스 코드

컬렉션 연관관계 페이징

176

작성자 없음

작성한 질문수 0

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]

안녕하세요. 페이징 처리에 대해서 질문이 있습니다.

 

엔티티로 조회를 하든지 DTO로 조회를 하든지 둘 다 컬렉션은 페이징 처리할 때 조회할 수 없는 것으로 알고 있는데요.

만약, 해당 컬렉션이 리스트 조회 조건에 포함되어 있다면 어떻게 처리하면 좋을까요?

 

@Entity
@Getter @Setter
@NoArgsConstructor(access = AccessLevel.PROTECTED)
@ToString(of = {"id", "name"})
public class Team {

    @Id @GeneratedValue
    @Column(name = "team_id")
    private Long id;
    private String name;

    @OneToMany(mappedBy = "team")
    private List<Member> members = new ArrayList<>();

    @OneToMany(mappedBy = "team")
    private List<Skill> skills = new ArrayList<>();

    public Team(String name) {
        this.name = name;
    }
}

 

예를 들어서 위와 같이 Team 엔티티가 있고, OneToMany 컬렉션으로 member와 skill 엔티티를 가지고 있습니다.

Team 엔티티를 페이징 처리해야 하는데, 검색 조건에 skill=[스킬1, 스킬2] , member=[멤버1, 멤버2] 가 있다고 하면 페이징처리할 때부터 where조건에 저 컬렉션을 넣어줘야 할 것 같은데, 페이징할 때는 컬렉션을 같이 조회하면 안된다고 알고 있어서 어떻게 해결해야 할지 고민입니다.

java spring spring-boot jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

고래밥님의 질문에 대한 답변으로, 컬렉션과 관련한 페이징 처리 방법에 대해 언급된 내용을 참고하시면 좋을 것 같습니다. 특히, “실전! 스프링 데이터 JPA” 강의에서 다루어진 페이징 질문과 비슷한 상황에서 컬렉션을 페이징 처리하는 방법이 구체적인 예시와 함께 설명되어 있습니다.

이 내용에서는 스프링 데이터 JPA를 사용하여 컬렉션 페이징 처리 시 발생할 수 있는 문제와 그에 대한 해결 방법으로 EntityGraph를 활용하는 방법과 페치 조인을 사용하는 경우 주의점, 그리고 페이징 처리 시 countQuery를 별도로 지정해주는 방식 등이 소개되고 있습니다. 특정 컬렉션을 where 조건에 포함시키려 할 때, @EntityGraph로 연관된 엔티티를 EAGER 로딩 하거나, JPAQueryFactory를 통한 Querydsl을 사용하여 컬렉션에 대한 조건을 추가하고 페이징 처리를 할 수 있는 방법이 제안되어 있습니다.

또한 DTO안에 컬렉션이 있는 경우에 대한 질문을 참고하시면, DTO를 활용할 때 컬렉션 처리를 어떻게 해야 하는지에 대한 방법도 얻을 수 있습니다.

각각의 상황에서 페이징을 어떻게 적용해야 할지 고민이신 경우, 이러한 답변들을 참고하시어 컬렉션을 포함한 페이징 처리 전략을 세우는 데 도움이 될 것입니다.

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

0

고래밥

컬렉션에 검색조건이 포함되어 페이징 쿼리에 컬렉션이 포함되어야 할 것 같은데, 강의 내용에는 이에 대한 설명이 없는 것 같습니다.

강의 관련 외 질문입니다.

0

66

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

0

89

1

BeanCreationException

0

87

3

Update 후 UpdateMemberResponse 매핑할 때

0

47

1

트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?

0

99

2

페이징 + 검색조건 관련해서 질문드립니다.

0

70

1

Query Dsl Q파일 질문입니다.

0

82

1

루트 쿼리라는것은

0

58

1

메서드를 분리하는 기준

0

63

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

110

3

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

0

84

2

fetch join과 영속화와 OSIV의 관계

0

85

2

Distinct 사용 전 결과에 대한 의문

0

113

2

레포지토리 계층에서의 트랜잭션에 대한 의문

0

56

1

영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.

0

78

2

dto 필드 속 엔티티 여부

0

60

1

뷰템플릿 사용 시

0

76

2

Result 클래스 관련 질문

0

56

1

@PostConstruct 프록시 관련 질문드립니다

0

86

1

DTO 대신 Form 사용은 안되나요?

0

135

1

OSIV ON 상태일 때

0

96

1

fetch join VS fetch join 페이징 궁금증

0

180

2

양방향 연관관계 알아보는 법?

0

105

1

16강 17강 간단 정리 이게 맞을까요 ?

0

165

2