• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    해결됨

default_batch_fetch_size 쿼리문

24.03.06 11:54 작성 24.03.06 12:14 수정 조회수 155

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

  select
        oi1_0.order_id,
        oi1_0.order_item_id,
        oi1_0.count,
        oi1_0.item_id,
        oi1_0.order_price 
    from
        order_item oi1_0 
    where
        oi1_0.order_id in (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)

batch.PNG

강의 4-4 페이징과 한계돌파 들으면서 똑같이 yml에 배치사이즈 100으로 하고 하던중

확인해보니 in문에 강의처럼 order 데이터 2개 있으니 '?' 2개로 보여야하는데

배치사이즈 설정한 수만큼 '?' 가 100개 이고 ,p6spy 보면 나머지 98개가 null로 들어갑니다..

org.hibernate.orm.jdbc.bind: trace 하고 확인해봐도 여전한데

하이버네이트나 머 다른게 업데이트후 저렇게 쿼리문 나가는게 정상이에요?

아니면 다른 문제이면서 저렇게 쿼리문 나가는건 성능에 안 좋은 영향 있을까요?

 

답변 1

답변을 작성해보세요.

2

tkdduf2122님의 프로필

tkdduf2122

2024.03.08

안녕하세요.

저도 이거 보고 좀 의아했는데 김영한님이 제공해주시는 문서를 보면 하이버네트 6버전부터 array_contains를 사용해서 쿼리를 재사용한다고 했는데, 아마 저희는 array_contains 대신 배치 사이즈 만큼 ?토큰이 다 채워진 쿼리를 재사용하는 것 같습니다. ?토큰 빈 값에는 null을 넣어주고 있는 것 뿐이고요.

찾아보니 김영한님이 답변해주신 것도 있네요ㅎㅎ

https://www.inflearn.com/questions/903628/19-04-%EC%B4%88-where-in-%EC%BF%BC%EB%A6%AC-%EB%8C%80%EC%8B%A0-where-array-conatins-%EC%BF%BC%EB%A6%AC%EA%B0%80-%EB%82%98%EC%99%94%EC%8A%B5%EB%8B%88%EB%8B%A4-%EC%8A%A4%ED%94%84%EB%A7%81-%EB%B6%80%ED%8A%B8-3-1

tkdduf2122님 답변 감사합니다.

Hermesi Choi님 추가로 링크를 읽어보시면 도움이 되실거에요. 하이버네이트 버전별로 최적화 방식이 조금씩 달라지더라구요.

참고로 이렇게 실행 되더라도 성능에는 영향이 없습니다 🙂

감사합니다.