mongodb Explain and Index
admin
2023-02-06 05:00:04
0

Explain and Index

    explain有三种模式,分别是:queryPlanner、executionStats、allPlansExecution。现实开发中,常用executionStats模式,本例分析这种模式。

> db.createCollection("person")

{ "ok" : 1 }

> for(var i=0;i<2000000;i++) {

... db.person.insert({"name":"ryan"+i,"age":i})

... }

WriteResult({ "nInserted" : 1 })

> db.person.find({"age":{"$lte":2000}}).explain("executionStats")

{
"queryPlanner" : {
"plannerVersion" : 1,
"namespace" : "test.person",
"indexFilterSet" : false,
"parsedQuery" : {
"age" : {
"$lte" : 2000
}
},
"winningPlan" : {
"stage" : "COLLSCAN",                "COLLSCAN"表示全表扫描
"filter" : {
"age" : {
"$lte" : 2000
}
},
"direction" : "forward"
},
"rejectedPlans" : [ ]
},
"executionStats" : {
"executionSuccess" : true,
"nReturned" : 2001,                    表示查询返回的条目数
"executionTimeMillis" : 741,           表示执行语句的执行时间
"totalKeysExamined" : 0,
"totalDocsExamined" : 2000000,         表示 文档扫描的条目数
"executionStages" : {
"stage" : "COLLSCAN",
"filter" : {
"age" : {
"$lte" : 2000
}
},
"nReturned" : 2001,
"executionTimeMillisEstimate" : 530,    表示整体的查询时间
"works" : 2000002,
"advanced" : 2001,
"needTime" : 1998000,
"needYield" : 0,
"saveState" : 15625,
"restoreState" : 15625,
"isEOF" : 1,
"invalidates" : 0,
"direction" : "forward",
"docsExamined" : 2000000
}
},
"serverInfo" : {
"host" : "meteor.yeecall.com",
"port" : 27027,
"version" : "3.2.8",
"gitVersion" : "ed70e33130c977bda0024c125b56d159573dbaf0"
},
"ok" : 1
}

> db.person.ensureIndex({age:1})    创建索引,“1”:表示按照age进行升序,“-1”:表示按照age进行降序

                                                 创建索引时ensureIndex({field:1},{name:"indexName"}) 可以指定索引的名称

                                                         也可以后台创建索引: db.collection.ensureIndex({name:-1},{background:true})

{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}

> db.person.find({"age":{"$lte":2001}}).explain("executionStats")

{
"queryPlanner" : {
"plannerVersion" : 1,
"namespace" : "test.person",    返回所查询的表
"indexFilterSet" : false,       针对该query是否有indexfilter
"parsedQuery" : {
"age" : {
"$lte" : 2001
}
},
"winningPlan" : {               查询优化器针对该query所返回的最优执行计划的详细内容
"stage" : "FETCH",
"inputStage" : {
"stage" : "IXSCAN",
"keyPattern" : {
"age" : 1
},
"indexName" : "age_1",
"isMultiKey" : false,
"isUnique" : false,
"isSparse" : false,
"isPartial" : false,
"indexVersion" : 1,
"direction" : "forward",
"indexBounds" : {
"age" : [
"[-inf.0, 2001.0]"
]
}
}
},
"rejectedPlans" : [ ]
},
"executionStats" : {
"executionSuccess" : true,
"nReturned" : 2002,                    表示本次查询返回的条目数
"executionTimeMillis" : 28,            表示本次query整体查询的时间
"totalKeysExamined" : 2002,            表示索引扫描的条目数
"totalDocsExamined" : 2002,            表示文档扫描的条目数
"executionStages" : {
"stage" : "FETCH",
"nReturned" : 2002,
"executionTimeMillisEstimate" : 10,    表示本次查询根据index检索document获得结果数据的时间
"works" : 2003,
"advanced" : 2002,
"needTime" : 0,
"needYield" : 0,
"saveState" : 15,
"restoreState" : 15,
"isEOF" : 1,
"invalidates" : 0,
"docsExamined" : 2002,
"alreadyHasObj" : 0,
"inputStage" : {
"stage" : "IXSCAN",
"nReturned" : 2002,
"executionTimeMillisEstimate" : 0,    表示该查询扫描2002行index所用的时间
"works" : 2003,
"advanced" : 2002,
"needTime" : 0,
"needYield" : 0,
"saveState" : 15,
"restoreState" : 15,
"isEOF" : 1,
"invalidates" : 0,
"keyPattern" : {
"age" : 1
},
"indexName" : "age_1",
"isMultiKey" : false,
"isUnique" : false,
"isSparse" : false,
"isPartial" : false,
"indexVersion" : 1,
"direction" : "forward",
"indexBounds" : {
"age" : [
"[-inf.0, 2001.0]"
]
},
"keysExamined" : 2002,
"dupsTested" : 0,
"dupsDropped" : 0,
"seenInvalidated" : 0
}
}
},
"serverInfo" : {
"host" : "meteor.yeecall.com",
"port" : 27027,
"version" : "3.2.8",
"gitVersion" : "ed70e33130c977bda0024c125b56d159573dbaf0"
},
"ok" : 1
}

>

影响 totalKeysExamined 和 totalDocsExamined 的是 stage 类型。

类型列举如下:

    COLLSCAN:全表扫描

    IXSCAN:索引扫描

    FETCH:根据索引去检索指定document

    SHARD_MERGE:将各个分片返回数据进行merge

    SORT:表明在内存中进行了排序

    LIMIT:使用limit限制返回数

    SKIP:使用skip进行跳过

    IDHACK:针对_id进行查询

    SHARDING_FILTER:通过mongos对分片数据进行查询

    COUNT:利用db.coll.explain().count()之类进行count运算

    COUNTSCAN:count不使用Index进行count时的stage返回

    COUNT_SCAN:count使用了Index进行count时的stage返回

    SUBPLA:未使用到索引的$or查询的stage返回

    TEXT:使用全文索引进行查询时候的stage返回

    PROJECTION:限定返回字段时候stage的返回

相关内容

热门资讯

【今日要闻】“免安装麻将机控制... 您好:免安装麻将机控制器这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家...
【今日要闻】“嘻游联盟有挂吗?... 有 亲,根据资深记者爆料嘻游联盟是可以开挂的,确实有挂(咨询软件无需打开...
今日重大发现“边锋老友棋牌是不... 今日重大发现“边锋老友棋牌是不是有挂?”(原来真的有挂)您好,边锋老友棋牌这个游戏其实有挂的,确实是...
【今日要闻】“九九牌游十三水有... 有 亲,根据资深记者爆料九九牌游十三水是可以开挂的,确实有挂(咨询软件无...
今日重大通报“福建大菠萝开挂器... 今日重大通报“福建大菠萝开挂器?”(原来真的有挂)您好,福建大菠萝这个游戏其实有挂的,确实是有挂的,...
我来教教您“打两圈泰兴麻将辅助... 家人们!今天小编来为大家解答打两圈泰兴麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪...
终于明白“嘻游联盟可以开挂吗?... 终于明白“嘻游联盟可以开挂吗?”(确实真的有挂)您好,嘻游联盟这个游戏其实有挂的,确实是有挂的,需要...
玩家最新攻略“决胜麻将有挂吗?... 网上科普关于“决胜麻将有没有挂”话题很是火热,小编也是针对决胜麻将作*弊开挂的方法以及开挂对应的知识...
【第一资讯】“来来麻将可以开挂... 您好:来来麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
终于懂了“麦穗app推筒子真的... 家人们!今天小编来为大家解答麦穗app推筒子透视挂怎么安装这个问题咨询软件客服徽9752949的挂在...