team이 존재하지않는 member가 존재할때 nullpointerExc
264
작성한 질문수 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
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





