inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

JPA Hint & Lock

쿼리 힌트 Page 추가 예제 질문

443

데스나이트

작성한 질문수 1

1

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
자료에 forCounting에 대한 설명을 적어주셨는데,
"Count쿼리도 쿼리 힌트 적용"한다는 설명이
@QueryHints의 forCounting값이 false이면 Count쿼리가 나가지 않는다는 말씀이신가요?

[자료 위치]
파일명 : "실전! 스프링 데이터 JPA -v2022-12-18.pdf"
위치 : "JPA Hint & Lock" > "JPA Hint" > "쿼리 힌트 Page 추가 예제"
영상 : "실전! 스프링 데이터 JPA" > "JPA Hint & Lock"

자료에는 "쿼리 힌트 Page 추가 예제"가 있지만 영상 11:44 이후 Lock으로 바로 넘어가서 저는 잘 이해가 안가네요.. ㅠㅠ

 

 

 

queryhints java forcounting spring spring-boot JPA

답변 1

1

김영한

안녕하세요. 데스나이트님

count 쿼리가 추가로 실행되는데, 이때 실행하는 count 쿼리에서는 힌트가 적용하지 않는다는 뜻입니다.

이 부분은 직접 한번 실행해보시면 쿼리 결과 로그를 보면 바로 답을 이해하실 수 있을거에요.

감사합니다.

0

데스나이트

자료에 forCounting 옵션을 넣으신 이유가 Pageable을 사용할 경우, 조회 쿼리와 Count쿼리를 구분해서 힌트를 적용할 수 있다는 말씀이시군요?

readOnly를 count쿼리에 적용하지 않을 때 더티체킹 하는것을 어떻게 확인하지? 라는 생각에 이해가 잘 안되었던것 같습니다.
( 일차원적으로 생각하는 성향이 있는듯합니다.. ㅠㅠ )

 

Comment 힌트를 넣어서 확인해보니 이해하기 쉬웠습니다.

application.yml ( use_sql_comments 옵션 추가 )

spring.jpa.hibernate.properties.hibernate.use_sql_comments: true

MemberRepository

@QueryHints(value = @QueryHint(name = "org.hibernate.comment", value = "memberRepository.findByUsername"), forCounting = false)
Page<Member> findByUsername(String name, Pageable pageable);

MemberRepositoryTest

@Test
void queryHint() {
    //given
    memberRepository.save(new Member("member1", 10));
    memberRepository.save(new Member("member1", 20));
    memberRepository.save(new Member("member1", 30));
    memberRepository.save(new Member("member1", 40));
    em.flush();
    em.clear();

    //when
    PageRequest pageRequest = PageRequest.of(0, 3, Sort.by(Sort.Direction.DESC, "username"));
    Page<Member> memberPage = memberRepository.findByUsername("member1", pageRequest);
}

로그

forCounting = false

/* select count(generatedAlias0) from Member as generatedAlias0 where generatedAlias0.username=:param0 */
select count(member0_.member_id) as col_0_0_ from member member0_ where member0_.username='member1';

forCounting = true

/* memberRepository.findByUsername */ select count(member0_.member_id) as col_0_0_ from member member0_ where member0_.username='member1';

 

새해 복 많이 받으세요.^^ OTL..

0

김영한

결과도 공유해주셔서 감사합니다^^ 새해 복 많이 받으세요.

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

0

75

1

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

0

108

3

MemberRepository 구현체

0

58

1

pdf 표현 질문드립니다.

0

63

1

로그가 남지 않는 문제.

0

83

1

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

0

72

2

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

0

73

2

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

0

94

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

179

2

교만했던 것 같아요.

0

147

1

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

0

149

2

동적 테이블에 대한 질문

0

86

1

영속성 전이와 연관관계

0

131

2

강의 10:25 질문

0

75

1

단건 update 질문

0

98

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

122

1

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

0

136

1