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

최강희님의 프로필 이미지
최강희

작성한 질문수

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

경로 표현식

t.members 값 확인이 되지 않습니다.

작성

·

397

0

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

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

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

[질문 내용]
String query = "select t.members From Team t";

Collection result = em.createQuery(query, Collection.class)
.getResultList();

System.out.println("result = " + result);

 

결과값

result = [hellojpa.Domain.Member@5b7aa898, hellojpa.Domain.Member@4e642ee1]

위와 같은 코드로 출력했는데 영상과 같이 리스트의 값이 나오지 않고 get 메소드도 사용도지 않아서 원하는 값들이 제대로 출력되는지 확인이 되지 않는데 왜그런건가요?

혹시 엔티티 설계할때 잘못했나 싶어서 아래에 엔티티 코드 남김니다.

@Entity
public class Member {

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

private String username;
private int age;

@ManyToOne
@JoinColumn(name = "TEAM_ID")
private Team team;

ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ

@Entity
public class Team {

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

private String name;

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

답변 2

0

안녕하세요. 최강희님, 공식 서포터즈 OMG입니다. AI 답변에 더하여 답변 드립니다.

Member클래스와 Team 클래스의 toString()을 재정의하여 확인해보시겠어요?

 

감사합니다.

0

안녕하세요, 인프런 AI 인턴이에요.

질문에 대한 답변을 드리겠습니다.

문제의 코드를 확인해보니 올바른 쿼리를 작성하셨는데, 출력 결과 값이 원하는 대로 나오지 않는 것 같습니다.

우선, 코드를 살펴보면 select t.members From Team t 부분에서 members 필드의 값을 조회하고, getResultList() 메소드를 통해 결과 값을 받아오고 있습니다. 그런데 실제 출력 결과로 보여주신 것은 Member 객체의 리스트가 출력되는 것이 아니라, Member 객체의 toString() 메소드를 통해 출력된 것 같습니다.

참고로, JPA에서는 엔티티들의 관계를 조회할 때 기본적으로 LAZY 로딩을 사용하고 있습니다. 이 경우에는 실제로 필요한 시점에 연관된 객체들을 조회하기 때문에 출력 결과에서는 둘 이상의 엔티티가 나오지 않고, 프록시 객체나 리프래시 등이 표시될 수 있습니다.

이 문제를 해결하기 위해서는 엔티티를 로딩할 때 연관된 객체들을 같이 로딩해야 합니다. 이를 위해 fetch join이나 @NamedEntityGraph와 같은 기능을 사용할 수 있습니다. fetch join은 JPQL에서 fetch 키워드를 사용하여 연관된 엔티티들을 함께 로딩하는 방식이며, @NamedEntityGraph는 엔티티 클래스에 정의하여 필요한 연관 엔티티들을 한 번에 로딩하는 방식입니다.

따라서, 코드에서 members 필드를 함께 로딩하도록 fetch join이나 @NamedEntityGraph를 적용하면 정상적으로 원하는 값들을 출력할 수 있을 것입니다.

그럼 질문하신 내용에 대해 도움이 되셨는지 확인해보시고, 추가적인 질문이 있으면 언제든지 물어보세요. 좋은 하루 보내세요!

최강희님의 프로필 이미지
최강희

작성한 질문수

질문하기