쿼리 캐싱관련 질문드립니다.
175
작성한 질문수 5
안녕하세요. 백기선님 강의 너무 잘 보고있습니다.
JPQL로 만든 쿼리가 캐싱이 안되는것 같아 질문드립니다.
테스트로 spring data jpa 의 findById를 JPQL 로 만들어보았습니다.
@Query("select p from Person p where p.id = :id")
public Person findByIdCustom(Long id);
동일한 트랜잭션에서 동일한 id로 위 쿼리를 여러번 호출하면 호출한 만큼 쿼리가 날아가고 있습니다ㅠ
JpaRepository 의 findById 를 여러번 호출하면 정상적으로 한번만 쿼리가 날아가고 이후에는 쿼리가 날아가지 않는데 제가 만든 위 쿼리를 사용하면 호출한 만큼 쿼리가 날아가 질문드립니다..
위 쿼리로 얻어온 엔티티 객체를 equals로 비교하면 전부 동일한 객체로 나오고 있는데도 쿼리가 여러번 호출됩니다.
답변 1
1
맞아요. JPQL로 만든 쿼리는 1차 캐시가 적용되지 않습니다. 2차 캐시를 적용해야 합니다. 스프링 데이터 JPA로 JPA를 쉽게 쓰는 방법에 대해 학습하는 것이 이 강의인데요. 1차 캐시나 2차 캐시를 이해하시려면 JPA나 하이버네이트 자체에 대해 학습하실 필요가 있습니다.
spring boot 2.7.13-SNAPSHOT trace 소문자 로그 안나옴
0
543
1
<스프링 데이터 Common: 기본 리포지토리 커스터마이징> 에 대한 질문
0
400
1
comment table에서 저장될떄 왜 id값이 2부터저장이되는건가요?
0
416
1
@EnableJpaRepositories 설정을 스프링부트가 어디에서 자동설정하나요?
0
456
0
PersistenceContext 관련 질문드립니다.
0
342
1
지금(Eager), 나중에(Lazy)의 의미를 모르겠습니다
0
345
1
transaction 구간이 길어질 경우의 처리방법 문의드립니다.
0
918
1
docker postgres
0
295
1
Multiple DataSource 사용 시 transaction 관련 질문 드립니다.
0
2918
1
entity 중 null이 아닌 필드만 update 할 방법이 있을까요?
0
1199
1
Eager 모드일 경우, join을 inner join으로 바꾸는 법이 있을까요?
0
388
1
엔티티를 상속받는 DTO가 일반적인가요?
1
1863
1
커스텀 타입 클래스를 String 타입 처럼 이용해 쿼리하는 방법에 대해 질문하고 싶습니다.
0
349
1
연관관계 매핑 어떤식으로 해야될지 감이 안잡힙니다.
0
577
4
EntityManager 주입시 Annotation관련 질문드립니다.
0
573
1
클래스 기반 프로젝션 사용 관련 질문
0
568
1
save 메서드 질문드립니다.
0
264
1
복잡한 통계쿼리도 JPA로 가능한가요?
2
5607
1
find 와 get의 차이가 무엇인가요?
0
902
1
실무에서 JPA 할 때 FK로 개발할때 연관관계를 꼭 맺어주어야 하나요?
0
1005
1
\dt Did not find any relations.
0
487
1
소스코드는 어디서 볼 수 있을까요?
1
295
1
table 생성과 select 문에 대한 질문
0
178
1
스프링 데이터 RepositoryTest 관련 질문
0
2176
2





