JPA Count 쿼리 Return 값
1516
작성한 질문수 1
안녕하세요 JPA 사용하다 궁금한게 생겨 질문드립니다.
현재 강의를 듣고 Spring Data JPA를 사용중인데요
공식 문서를 보니 count query 시 return 값이 Long(Wrapper Type)으로 반환된다 합니다.
혹시나 싶어서 jpa에서 count 후 return class type을 보니 java.lang.Long으로 반환되네요....
궁금한건 count는 sql도 그렇고 jpa 문서상에도 null인 경우가 없는것으로 보이는데요
JPA에서 Count 쿼리 호출시 primitive가 아닌 Wrapper로 반환하는 이유가 있을까요??
엔티티 ID처럼 nullable로 인한 이득이 있는것도 아닌데, 결과값을 박싱해서 내려주는게 어떤 이득이 있는지 모르겠습니다.
마지막으로 Long으로 반환되는 결과값을 아래처럼 long으로 unboxing 해서 사용해도 성능이나 여러가지면에서 손해보는면이 있을까요?
@Query("select count(m) from ....... wherer ....")
long countMember();
답변 1
1
안녕하세요. yesorachoi님
primitive 타입 대신에 Long 타입으로 내리도록 정의한 정확한 이유는 저도 모르겠습니다.
아마도 하이버네이트 전반에 min, max를 포함해서 일관성을 위해 Long을 사용한 것 같아요. 이런 경우는 null이 반환될 수도 있으니까요.
그리고 애플리케이션 전체로 보면 boxing, unboxing 비용은 거의 0에 가깝습니다.
따라서 성능 걱정하지 않고 사용하셔도 됩니다.
감사합니다.
실무 조언 관련 질문입니다.
0
36
1
H2데이터베이스 파일 생성
0
45
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
47
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
45
1
JPQL 메소드와 락
0
47
1
Delivery @OneToOne
0
54
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
84
2
UnsupportedOperationException 발생
0
80
3
H2 Database 연결이 안됩니다.
0
86
2
연관관계 매핑 질문드립니다.
0
77
2
h2데이터베이스 실행오류
0
103
2
persistence.xml
0
100
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
74
1
영속성 컨텍스트
0
59
1
JPA 프록시
0
86
1
Native Query와 MyBatis
0
60
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
81
1
임베디드 타입 예시 코드 관련 질문
0
110
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
89
3
인텔리제이 패키지 커서 단축키 질문
0
100
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
133
1
양방향 연관관계 시 연관관계 주인을 설정하는 이유
0
67
1
임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.
0
95
1
데이터베이스가 초기화되는 것 같아요
1
172
2





