강의

멘토링

로드맵

Inflearn brand logo image

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

큐펀치님의 프로필 이미지
큐펀치

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

페치 조인 1 - 기본

일대다 페치 조인 데이터 뻥튀기

작성

·

209

·

수정됨

1

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

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

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

[질문 내용]
여기에 질문 내용을 남겨주세요.

강의에서 컬렉션을 페치 조인했을때 컬렉션의 요소 만큼 결과 리스트가 증가한다 하였습니다. 하지만 아래와 같이 코드를 실행했는데 결과는 한번만 출력이 됩니다.

찾아보니 JPA에서 내부적으로 중복을 없애준다는데 맞는 이야기 인가요??

package jpashop.jpql;

import jakarta.persistence.EntityManager;
import jakarta.persistence.EntityManagerFactory;
import jakarta.persistence.EntityTransaction;
import jakarta.persistence.Persistence;

import java.util.List;

public class Main {
    public static void main(String[] args) {
        EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");

        EntityManager em = emf.createEntityManager();
        //트랜잭션 생성
        EntityTransaction tx = em.getTransaction();
        //트랜잭션 시작
        tx.begin();
        try {
             Team teamA=new Team();
             teamA.setName("팀A");
             em.persist(teamA);

            Team teamB=new Team();
            teamB.setName("팀B");
            em.persist(teamB);

             Member member1=new Member();
             member1.setUsername("member1");
             member1.setAge(10);
             member1.setTeam(teamA);
             em.persist(member1);

            Member member2=new Member();
            member2.setUsername("member2");
            member2.setTeam(teamA);
            member2.setAge(15);
            em.persist(member2);

            Member member3=new Member();
            member3.setUsername("member3");
            member3.setTeam(teamB);
            member3.setAge(20);
            em.persist(member3);

             em.flush();
             em.clear();
            String query="select t From Team t join fetch t.members where t.name='팀A'";

            List<Team> result = em.createQuery(query, Team.class)
                    .getResultList();
                for (Team t:result){
                    System.out.println("member= " +t.getName()+"|members="+t.getMembers().size());
                    for (Member m:t.getMembers()){
                        System.out.println("- member ="+m);
                    }
                }
            tx.commit();

        }catch (Exception e){
            e.printStackTrace();
            tx.rollback();
        }finally {
            em.close();
        }
        emf.close();
    }
}
 
aa.PNG

 
String query="select t From Team t join fetch t.members";

String query="select t From Team t";

 

두 결과 사이즈를 찍어도 동일하게 2가 나옵니다.

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 큐펀치님.

질문하신 일대다 페치 조인 데이터 뻥튀기 문제에 대해 설명드리겠습니다.

JPA를 사용할 때, 페치 조인(Fetch Join)을 통해 연관된 엔티티를 함께 로딩할 수 있습니다. 일반적으로 컬렉션을 페치 조인하면 컬렉션에 포함된 요소의 개수만큼 결과가 증가합니다. 하지만, Hibernate 6버전부터는 중복된 엔티티를 제거하는 기능이 자동으로 적용됩니다. 이는 페치 조인 시 발생할 수 있는 불필요한 중복 데이터를 없애서 최적화된 결과를 제공하기 위함입니다.

따라서, 컬렉션을 페치 조인했음에도 불구하고 중복되지 않는 결과를 얻을 수 있게 됩니다. 페치 조인에 의해 과거에는 중복된 엔티티 객체가 결과 리스트에 포함되었을 수 있으나, Hibernate 6에서는 이러한 중복을 필터링하여 반환하게 됩니다.

관련 문서에서도 이와 같은 내용이 언급되어 있으며, 다음의 링크를 통해 상세한 내용을 확인하실 수 있습니다: Hibernate ORM 6.0 Migration Guide

추가적으로, 여러분에게 유용할 유사한 질문을 함께 공유드립니다:
- 페치 조인 및 중복 제거 관련 문제 해결 팁

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

큐펀치님의 프로필 이미지
큐펀치

작성한 질문수

질문하기