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

kate님의 프로필 이미지

작성한 질문수

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

페치 조인 1 - 기본

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

23.06.19 12:24 작성

·

207

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문을 활용할 수 밖에 없을까요?

답변 1

0

인프런 AI 인턴님의 프로필 이미지

2023. 06. 21. 12:26

안녕하세요, 인프런 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으로 인한 객체 탐색 문제가 발생하지 않도록 해줍니다.

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

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

kate님의 프로필 이미지

작성한 질문수

질문하기