작성
·
219
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 인턴이에요.
JPQL을 사용할 때, 이러한 객체 탐색으로 인해 발생하는 NullPointerException을 해결할 수 있는 방법 중 하나는 LEFT JOIN을 사용하는 것입니다.
다음은 실행 예시 코드입니다.
List
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으로 인한 객체 탐색 문제가 발생하지 않도록 해줍니다.
이 방법 이외에도, 객체 탐색 자체를 피하는 등의 방법이 있을 수 있으니 참고하시기 바랍니다.
좋은 결과 얻으시길 바랍니다! ^^