>  기사  >  MongoDB 보기 실행 계획

MongoDB 보기 실행 계획

小云云
小云云원래의
2017-12-09 16:12:381985검색

이 기사에서는 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

indexFilterSetindex 사용 여부query 조건은 x=1에 대한 IDHACK/쿼리 다른 매개변수 추가explain()도 다른 매개변수를 설정하여 더 자세한 쿼리 계획을 볼 수 있습니다. queryPlannerqueryPlanner는 기본 매개변수입니다. queryPlanner 매개변수를 추가한 후의 쿼리 결과는 위에서 본 쿼리 결과이므로 여기서는 자세히 설명하지 않겠습니다. executionStatsexecutionStats는 다음과 같이 최상의 실행 계획에 대한 일부 통계 정보를 반환합니다. 위에서 소개한 일부 매개변수 외에도 다음과 같은 의미를 지닌 ExecutionStats 매개변수도 있습니다.
parsedQuery
winingPlan 최고의 실행 계획
stage입니다. 쿼리 방법, 공통사항이 있습니다 COLLSCAN/ 전체 테이블 스캔, IXSCAN/인덱스 스캔, 인덱스 기반 문서 FETCH/검색, SHARD_MERGE/샤드 결과 병합, _id
filter 필터 조건
direction 검색 방향
rejectedPlans 거부된 실행 계획
serverInfo MongoDB 서버 정보
{
    "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
}
매개변수 의미

executionSuccess

실행 성공 여부

nReturned

반환된 결과 수

executionTimeMillis실행 시간 인덱스 스캔 수allPlansExecutionallPlansExecution을 사용하여 모든 실행 계획을 가져오는 데 사용되며 기본적으로 결과 매개 변수는 위와 동일하므로 생략하겠습니다. 여기에서 자세히 알아보세요. 자, 이제 MongoDB의 explain()에 대한 이야기는 그만 합시다. 질문이 있으시면 토론을 위해 메시지를 남겨주세요. 관련 권장사항: MongoDB 팁 및 주의사항 요약
totalKeysExamined
totalDocsExamined 문서 스캔 횟수
executionStages 이 카테고리는 실행 상태를 설명합니다
stage 스캔 방법, 구체적인 선택값은 위와 같습니다
n반환 쿼리 결과 개수
executionTimeMillisEstimate 예상 시간 소모
works 작업 단위 수, 쿼리가 작은 작업 단위로 분할됩니다
advanced 반환된 결과 수 first
docsEx amined Documentation 검사 횟수는 totalDocsExamined
MongoDB 고정 컬렉션에 대한 자세한 설명
mongodb 데이터베이스 사용 방법에 대한 Laravel 튜토리얼
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.