inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

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

해결된 질문

204

eoyeong

작성한 질문수 57

0

안녕하세요.

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

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

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

java mysql spring-boot kafka redis

답변 2

1

쿠케

eoyeong님, 안녕하세요!

 

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

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

0

eoyeong

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

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

2

쿠케

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

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

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

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

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

1

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 쿼리 실행 계획에서 나타나는 다양한 요소들을 설명하고 있습니다. 이를 통해 보다 깊이 있게 이해를 높일 수 있습니다.

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

@Version 어노테이션이 붙은 필드는 낙관적 락이든 비관적 락이든 업데이트가 됩니다.

0

32

1

consumer에서 에러가 발생할 경우 데이터 유실 문의

0

49

2

게시글 테스트 데이터 삽입

0

51

2

정렬, 필터, 검색 등의 조건이 붙을 경우 최적화할 수 있는 방법이 무엇이 있을까요?

0

104

2

좋아요 기능 정합성 보장 방법

0

98

2

좋아요 동시성처리 최적의 선택?

1

138

2

프론트엔드 msa 환경 api 주소 통합? 과 서버끼리 통신 방식에대해

0

92

2

안녕하세요 무한스크롤 강의듣다가 질문이 있습니다.

0

61

1

조회수 조회 로직 질문

1

67

2

비로그인 유저도 어뷰징 방지 정책

1

73

2

CommentServiceTest의 테스트 로직 질문

0

54

2

무한 스크롤 방식에서 페이지 번호 방식 쿼리의 문제점 의문

1

74

2

path 쿼리 관련 질문드립니다!

0

60

2

antigravity 에디터를 쓰신다면 종료해주세요

1

123

0

프로젝트 구조

0

88

2

article_like_count api test

0

79

2

이벤트 페이로드 객체의 생성 방식이 팩토리 메서드 패턴이 아닌 빌더 패턴인 이유가 궁금합니다!.

0

104

2

[33. 좋아요 수 구현] 에서 테스트 하는 화면 동시성 문제

0

92

2

findByPath에서 articleId로도 검색을 해야 할 것 같아요.

0

94

3

jpa ddl-auto none을 하는 이유와 join 방법

0

97

2

팩터리 메소드와 response 객체 사용 이유가 궁금합니다!

0

91

2

커서 기반 페이지네이션 과 무한 스크롤링

0

112

2

게시글 생성 로직에서 오류 발생시 redis 게시글 수 되돌리기

0

97

2

멀티 모듈이 아닌 MSA 환경에서 common

0

158

2