inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

경로 표현식

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

485

최강희

작성한 질문수 1

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<>();

java jpa

답변 2

0

OMG

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

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

 

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 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를 적용하면 정상적으로 원하는 값들을 출력할 수 있을 것입니다.

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

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

15

2

inheritance startegy 선택시 고려사항

0

21

1

Entity 동등성 비교

0

18

1

실무 조언 관련 질문입니다.

0

44

1

H2데이터베이스 파일 생성

0

55

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

52

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

51

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

92

2

UnsupportedOperationException 발생

0

85

3

H2 Database 연결이 안됩니다.

0

92

2

연관관계 매핑 질문드립니다.

0

85

2

h2데이터베이스 실행오류

0

107

2

persistence.xml

0

106

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

80

1

영속성 컨텍스트

0

64

1

JPA 프록시

0

94

1

Native Query와 MyBatis

0

67

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

85

1

임베디드 타입 예시 코드 관련 질문

0

114

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

94

3

인텔리제이 패키지 커서 단축키 질문

0

108

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

142

1