team이 존재하지않는 member가 존재할때 nullpointerExc
267
작성한 질문수 23
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으로 인한 객체 탐색 문제가 발생하지 않도록 해줍니다.
이 방법 이외에도, 객체 탐색 자체를 피하는 등의 방법이 있을 수 있으니 참고하시기 바랍니다.
좋은 결과 얻으시길 바랍니다! ^^
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
63
2
inheritance startegy 선택시 고려사항
0
44
1
Entity 동등성 비교
0
48
1
실무 조언 관련 질문입니다.
0
71
1
H2데이터베이스 파일 생성
0
80
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
70
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
65
1
JPQL 메소드와 락
0
64
1
Delivery @OneToOne
0
75
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
106
2
UnsupportedOperationException 발생
0
98
3
H2 Database 연결이 안됩니다.
0
105
2
연관관계 매핑 질문드립니다.
0
97
2
h2데이터베이스 실행오류
0
119
2
persistence.xml
0
127
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
93
1
영속성 컨텍스트
0
80
1
JPA 프록시
0
108
1
Native Query와 MyBatis
0
86
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
99
1
임베디드 타입 예시 코드 관련 질문
0
130
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
103
3
인텔리제이 패키지 커서 단축키 질문
0
114
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
157
1





