이 기사에서는 MongoDB 실행 계획 보기에 대한 지식을 공유하여 모든 사람에게 도움이 되기를 바랍니다. MongoDB의 explain() 함수를 사용하면 쿼리 관련 정보를 볼 수 있어 검색 병목 현상을 빠르게 찾아 해결할 수 있습니다. 이 기사에서는 explain()의 몇 가지 용도와 쿼리 결과의 의미를 살펴보겠습니다.
1. Linux에 MongoDB 설치
3. MongoDB 데이터 유형
4. MongoDB 문서 쿼리 작업(1)
6. MongoDB 문서 쿼리 연산 (3)
일반적으로 explain()의 사용법은 sort(),limit()의 사용법과 유사하지만, explain()은 맨 마지막에 위치해야 한다는 점이 다릅니다.
기본 사용법먼저 기본 사용법을 살펴보겠습니다.
db.sang_collect.find({x:1}).explain()
는 find() 함수 바로 뒤에 나오며, find() 함수의 실행 계획을 보겠다는 의미입니다.
{ "queryPlanner" : { "plannerVersion" : 1, "namespace" : "sang.sang_collect", "indexFilterSet" : false, "parsedQuery" : { "x" : { "$eq" : 1.0 } }, "winningPlan" : { "stage" : "COLLSCAN", "filter" : { "x" : { "$eq" : 1.0 } }, "direction" : "forward" }, "rejectedPlans" : [] }, "serverInfo" : { "host" : "localhost.localdomain", "port" : 27017, "version" : "3.4.9", "gitVersion" : "876ebee8c7dd0e2d992f36a848ff4dc50ee6603e" }, "ok" : 1.0 }반환 결과입니다. 두 가지 큰 정보가 포함되어 있습니다. 하나는 쿼리 계획인 queryPlanner이고 다른 하나는 MongoDB 서비스에 대한 일부 정보인 serverInfo입니다. 여기에 관련된 매개변수가 많으므로 하나씩 살펴보겠습니다. 있다 queryed indexFilterSet
parsedQuery | |
---|---|
winingPlan | 최고의 실행 계획 |
stage입니다. | 쿼리 방법, 공통사항이 있습니다 COLLSCAN/ 전체 테이블 스캔, IXSCAN/인덱스 스캔, 인덱스 기반 문서 FETCH/검색, SHARD_MERGE/샤드 결과 병합, _id |
filter | 필터 조건 |
direction | 검색 방향 |
rejectedPlans | 거부된 실행 계획 |
serverInfo | MongoDB 서버 정보 |
다른 매개변수 추가 | explain()도 다른 매개변수를 설정하여 더 자세한 쿼리 계획을 볼 수 있습니다. |
queryPlanner는 기본 매개변수입니다. queryPlanner 매개변수를 추가한 후의 쿼리 결과는 위에서 본 쿼리 결과이므로 여기서는 자세히 설명하지 않겠습니다. | executionStats |
{ "queryPlanner" : { "plannerVersion" : 1, "namespace" : "sang.sang_collect", "indexFilterSet" : false, "parsedQuery" : {}, "winningPlan" : { "stage" : "COLLSCAN", "direction" : "forward" }, "rejectedPlans" : [] }, "executionStats" : { "executionSuccess" : true, "nReturned" : 10000, "executionTimeMillis" : 4, "totalKeysExamined" : 0, "totalDocsExamined" : 10000, "executionStages" : { "stage" : "COLLSCAN", "nReturned" : 10000, "executionTimeMillisEstimate" : 0, "works" : 10002, "advanced" : 10000, "needTime" : 1, "needYield" : 0, "saveState" : 78, "restoreState" : 78, "isEOF" : 1, "invalidates" : 0, "direction" : "forward", "docsExamined" : 10000 } }, "serverInfo" : { "host" : "localhost.localdomain", "port" : 27017, "version" : "3.4.9", "gitVersion" : "876ebee8c7dd0e2d992f36a848ff4dc50ee6603e" }, "ok" : 1.0 } | 위에서 소개한 일부 매개변수 외에도 다음과 같은 의미를 지닌 ExecutionStats 매개변수도 있습니다. |
매개변수 | 의미 |
totalKeysExamined | |
---|---|
totalDocsExamined | 문서 스캔 횟수 |
executionStages | 이 카테고리는 실행 상태를 설명합니다 |
stage | 스캔 방법, 구체적인 선택값은 위와 같습니다 |
n반환 | 쿼리 결과 개수 |
executionTimeMillisEstimate | 예상 시간 소모 |
works | 작업 단위 수, 쿼리가 작은 작업 단위로 분할됩니다 |
advanced | 반환된 결과 수 first |
docsEx amined | Documentation 검사 횟수는 totalDocsExamined |
allPlansExecution | allPlansExecution을 사용하여 모든 실행 계획을 가져오는 데 사용되며 기본적으로 결과 매개 변수는 위와 동일하므로 생략하겠습니다. 여기에서 자세히 알아보세요. |
관련 권장사항: | |
MongoDB 고정 컬렉션에 대한 자세한 설명 | |
mongodb 데이터베이스 사용 방법에 대한 Laravel 튜토리얼 |
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사
어 ass 신 크리드 그림자 : 조개 수수께끼 솔루션
4 몇 주 전ByDDD
Windows 11 KB5054979의 새로운 기능 및 업데이트 문제를 해결하는 방법
3 몇 주 전ByDDD
Atomfall에서 크레인 제어 키 카드를 찾을 수 있습니다
4 몇 주 전ByDDD
<s> : 데드 레일 - 모든 도전을 완료하는 방법
1 몇 달 전ByDDD
KB5055523을 수정하는 방법 Windows 11에 설치되지 않습니까?
2 몇 주 전ByDDD

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구
