쿼리 힌트 Page 추가 예제 질문
443
작성한 질문수 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으로 바로 넘어가서 저는 잘 이해가 안가네요.. ㅠㅠ
답변 1
1
안녕하세요. 데스나이트님
count 쿼리가 추가로 실행되는데, 이때 실행하는 count 쿼리에서는 힌트가 적용하지 않는다는 뜻입니다.
이 부분은 직접 한번 실행해보시면 쿼리 결과 로그를 보면 바로 답을 이해하실 수 있을거에요.
감사합니다.
0
자료에 forCounting 옵션을 넣으신 이유가 Pageable을 사용할 경우, 조회 쿼리와 Count쿼리를 구분해서 힌트를 적용할 수 있다는 말씀이시군요?
readOnly를 count쿼리에 적용하지 않을 때 더티체킹 하는것을 어떻게 확인하지? 라는 생각에 이해가 잘 안되었던것 같습니다.
( 일차원적으로 생각하는 성향이 있는듯합니다.. ㅠㅠ )
Comment 힌트를 넣어서 확인해보니 이해하기 쉬웠습니다.
application.yml ( use_sql_comments 옵션 추가 )
spring.jpa.hibernate.properties.hibernate.use_sql_comments: trueMemberRepository
@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..
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





