인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

eoyeong님의 프로필 이미지

작성한 질문수

스프링부트로 직접 만들면서 배우는 대규모 시스템 설계 - 게시판

게시글 목록 API - 무한 스크롤 구현

무한 스크롤 쿼리 질문 있습니다.

해결된 질문

작성

·

114

0

  • 학습 관련 질문을 최대한 상세히 남겨주세요!

  • 고민 과정도 같이 나열해주셔도 좋습니다.

  • 먼저 유사한 질문이 있었는지 검색해보세요.

  • 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

안녕하세요.

select * from article where board_id = 1 order by article_id desc limit 30;

해당 쿼리에서 강사님은 Extra에 null인데 제가 실행하면 using where가 나오네요.

using filesort는 안나오는데 크게 상관 없는 부분일까요?

답변 2

1

쿠케님의 프로필 이미지
쿠케
지식공유자

eoyeong님, 안녕하세요!

 

무한 스크롤 진행할 때라면 인덱스도 이미 걸려있는 상황일테고, using where가 뜨지 않아야할 것 같네요.

혹시 테스트 데이터가 적은 상황일까요?

eoyeong님의 프로필 이미지
eoyeong
질문자

넵 테스트 데이터를 100건 정도만 넣고 돌렸습니다.

데이터의 양에 따라 index 타는게 달라지나요??

쿠케님의 프로필 이미지
쿠케
지식공유자

옵티마이저는 데이터에 따라서 최적화 방법이 달라지기도 하는데요,

데이터가 적으면 의도한 인덱스를 타는 것보다 다른 방법(풀스캔 또는 다른 인덱스 등)이 더 빠르다고 판단할 수도 있습니다!

100건 정도라면, 필터링에 대해서는 그냥 where 조건 태우는게 더 빠르다고 판단했을 것 같네요!

filesort도 데이터가 많아서 메모리로 한번에 끌어올 수 없는 경우에 디스크를 활용하여 큰 비용으로 처리되는거라, 데이터가 작다면 메모리로 한번에 끌어와서 처리하면 되기 때문에 정렬 비용도 크게 들지 않습니다. 아니면 정렬에 대해서는 클러스터드 인덱스를 탔을 수도 있고요. 클러스터드 인덱스를 바로 탔다면, key=PRIMARY라고 적혀있을겁니다!

한 10만건? 정도 넣어서 다시 쿼리 플랜 살펴보면 결과가 달라지지 않을까 싶네요.

eoyeong님의 프로필 이미지
eoyeong
질문자

아하! 감사합니다!

항상 너무 자세하게 답변해주셔서 감사합니다 ㅠㅠ

0

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다. eoyeong님.

SQL 쿼리를 실행할 때 EXPLAIN 명령어를 통해 결과로 나오는 Using where와 관련된 문제에 대해 답변드리겠습니다. 이는 데이터베이스가 쿼리를 최적화하는 방식 및 실행 계획의 차이와 관련이 있습니다.

Using where가 나오는 이유

  • Using where는 MySQL이 WHERE 절을 사용하여 데이터를 필터링하고 있음을 나타냅니다. 이는 데이터베이스가 쿼리의 WHERE 조건을 기반으로 필요한 데이터를 정확히 선택하고 있다는 신호입니다.
  • 예를 들어, board_id = 1 이라는 조건이 있으므로, MySQL은 해당 조건을 만족하는 레코드를 조회하기 위해 WHERE 절을 사용하게 됩니다.

Using filesort가 안 나오는 이유

  • Using filesort가 나오지 않는다는 것은, 정렬을 위한 추가적인 디스크 작업이 필요하지 않음을 의미합니다. 주어진 인덱스나 데이터 구조가 정렬된 데이터를 효율적으로 반환할 수 있다는 의미로 해석됩니다.

따라서 Using where가 나타나는 것은 정상적인 동작이며, 데이터가 WHERE 절을 기준으로 필터링되어 실행되는 중이라는 것을 알 수 있습니다. 이는 성능에 큰 영향을 미치는 요소가 아니므로, 일반적인 작업에서는 큰 문제가 되지 않습니다.

참고 자료

더 많은 정보를 얻고 싶으시면 유사한 상황에 대한 다른 질문과 답변을 참고해 보세요:

위 링크에서는 MySQL 쿼리 실행 계획에서 나타나는 다양한 요소들을 설명하고 있습니다. 이를 통해 보다 깊이 있게 이해를 높일 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

eoyeong님의 프로필 이미지

작성한 질문수

질문하기