inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

순수 JPA 페이징과 정렬

createQuery

432

성실한 공작새

작성한 질문수 4

0

public List<Member> findByPage(int age, int offset, int limit){
        return em.createQuery("select m from Member m where m.age = :age order by m.username desc")
                .setParameter("age", age)
                .setFirstResult(offset)
                .setMaxResults(limit)
                .getResultList();
    }
em.createQuery("select m from Member m where m.age = :age order by m.username desc", Member.class)

아래처럼 끝에 반환하는 클래스 타입을 적어줘야 된다고 기억을 하는데 위에 코드 처럼 적어주지 않아도 정상적으로 작동을 하더라구요?

반면에

public long totalCount(int age){
        return em.createQuery("select count(m) from Member m where m.age = :age")
                .setParameter("age", age)
                .getSingleResult();
    }

totalCount 의 경우 클래스 타입을 안적어주면 바로 빤갈줄이 그어지는데

반환하는 클래스 타입이 생략이 가능한 경우도 있는건가요??

java spring spring-boot jpa

답변 1

2

David

안녕하세요. 성실한 공작새님, 공식 서포터즈 David입니다.

타입을 명시하지 않으면 Object로 반환됩니다.

Member를 조회했기 때문에 Object는 Member로 타입 캐스팅이 가능합니다. 따라서, 오류가 발생하지 않은 것입니다.

동일하게 타입을 명시하지 않고 count 값을 getSingleResult()로 가져오면 Object로 가져옵니다. 그런데 Object 타입을 Long(wrapper type)이 아니라 long(primitive type)으로 캐스팅하려 하니 오류가 발생하는 걸로 보입니다.

long이 아니라 Long 타입을 사용해 보시겠어요?

그리고 특별한 이유가 아니라면 반환 받을 타입을 명시하여 불필요하게 발생할 수 있는 오류를 방지하는 것이 좋습니다:)

감사합니다.

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

72

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

107

3

MemberRepository 구현체

0

58

1

pdf 표현 질문드립니다.

0

62

1

로그가 남지 않는 문제.

0

81

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

72

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

73

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

92

2

Sort 인터페이스는 잘 사용 안하나요?

0

52

1

스캔대상 질문드립니다.

0

46

1

하이버네이트6에서의 최적화에 이은 질문

0

86

1

save() vs saveAndFlush DB 통신 횟수

0

54

1

순수 JPA 리포지토리 코드 수정부분

0

86

2

bulk연산 후 flush하는 이유를 모르겠어요

0

152

3

bulk insert 질문입니다.

0

178

2

교만했던 것 같아요.

0

147

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

148

2

동적 테이블에 대한 질문

0

86

1

영속성 전이와 연관관계

0

131

2

강의 10:25 질문

0

74

1

단건 update 질문

0

96

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

121

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

136

1