inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

페치 조인 1 - 기본

team이 존재하지않는 member가 존재할때 nullpointerExc

264

kate

작성한 질문수 23

0

Team team = new Team();
team.setName("TeamA");
em.persist(team);
Team team2 = new Team();
team2.setName("TeamB");
em.persist(team2);
Member member1 = new Member();
member1.setUsername("회원1");
member1.setTeam(team);
em.persist(member1);
Member member2 = new Member();
member2.setUsername("회원2");
member2.setTeam(team);
em.persist(member2);
Member member3 = new Member();
member3.setUsername("회원3");
member3.setTeam(team2);
em.persist(member3);
Member member4 = new Member();
member4.setUsername("회원4");
member3.setTeam(null);
em.persist(member4);
em.flush();
em.clear();

List<Member> lazyLoadingResult = em.createQuery("select m from Member m ", Member.class).getResultList();
for (Member member : lazyLoadingResult) {
    System.out.println("member = " + member.getUsername() + ", " + ((member.getTeam().getName() == null) ? "null" : member.getTeam().getName()));
}

위와 같이 team이 존재하지 않는 Member 데이터를 추가한 뒤에 inner join을 하게될 경우

nullpointerException이 발생합니다.

객체 탐색을 활용하면 발생하게 되는 문제로 이해는 했지만 JPQL을 사용하였을 때 이에 대한 해결책으로는 어떤 게 있을까요?

3항연산자로 사용 처리를 해보려고 하였으나 객체 탐색이기 때문에 처리가 되지 않고 있습니다.

case문을 활용할 수 밖에 없을까요?

java jpa

답변 1

0

인프런 AI 인턴

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

JPQL을 사용할 때, 이러한 객체 탐색으로 인해 발생하는 NullPointerException을 해결할 수 있는 방법 중 하나는 LEFT JOIN을 사용하는 것입니다.

다음은 실행 예시 코드입니다.

List lazyLoadingResult = em.createQuery(“select m from Member m left join fetch m.team”, Member.class).getResultList();
for (Member member : lazyLoadingResult) {
System.out.println(“member = ” + member.getUsername() + “, ” + ((member.getTeam() == null) ? “null” : member.getTeam().getName()));
}

위와 같이 left join fetch를 사용하면, Member 테이블과 일치하는 Team 테이블을 조인하면서도 Member 테이블만 참조하는 경우에도 null이 반환됩니다. 이는 lazy loading으로 인한 객체 탐색 문제가 발생하지 않도록 해줍니다.

이 방법 이외에도, 객체 탐색 자체를 피하는 등의 방법이 있을 수 있으니 참고하시기 바랍니다.

좋은 결과 얻으시길 바랍니다! ^^

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

0

24

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

18

1

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

0

46

1

H2데이터베이스 파일 생성

0

56

2

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

0

52

2

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

0

51

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

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

0

93

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

92

2

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

0

85

2

h2데이터베이스 실행오류

0

107

2

persistence.xml

0

106

2

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

0

80

1

영속성 컨텍스트

0

65

1

JPA 프록시

0

95

1

Native Query와 MyBatis

0

68

1

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

0

85

1

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

0

114

3

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

0

94

3

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

0

108

2

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

0

143

1