TIL

[TIL] 2023.06.27

DevHyo 2023. 6. 27. 21:40

 MySQL 쿼리 사용 시, IN절 최적화

MySQL 쿼리 사용 시, IN절을 자주 사용하는 편이다. 지금까지 알고 있었던 내용으로 IN절은 최대 1,000개까지 사용해도 성능에 크게 문제가 없을 줄 알았다. 그런데 1,000개를 사용해도 MySQL 옵션에 따른 옵티마이저의 실행 계획에 따라 성능이 좋지 않을 수도 있다는 것을 알게 되었다. 상황에 따라 1,000개까지 사용하고 싶다면, IN절의 개수를 조금씩 늘려가면서 성능 테스트를 진행해야 한다는 것도 추가로 알게 되었다.

주요 키워드

  • Index Range Scan, index dive
  • Index Range Scan, index statistics
  • MySQL의 eq_range_index_dive_limit 옵션
  • MySQL의 range_optimizer_max_mem_size 옵션
  • Spring JPA(Hibernate)에서 default_batch_fetch_size 설정
  • Spring Batch에서 Chunk Size 설정

정리한 내용

https://github.com/bestdevhyo1225/dev-log/blob/master/JPA/Default_Batch_Fetch_Size_Chunk_Size_Check_List.md

 

GitHub - bestdevhyo1225/dev-log: :memo: Record

:memo: Record. Contribute to bestdevhyo1225/dev-log development by creating an account on GitHub.

github.com