찾다
헤드라인MongoDB 보기 실행 계획

MongoDB 보기 실행 계획

Dec 09, 2017 pm 04:12 PM
mongodb확인하다계획

이 기사에서는 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으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

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

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

맨티스BT

맨티스BT

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

PhpStorm 맥 버전

PhpStorm 맥 버전

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