数据库|mysql教程
MongoDB,操作手册,CRUD,查询,性能,分析,分析,
数据库-mysql教程
珠宝公司网源码,vscode设置字间距,ubuntu安装办公,tomcat设置日志大小,javaw爬虫,php判断文件是否为空,seo优化提升内容推广,校园代取快递网站源码,企业服务中心模板lzw
分析查询性能 explain() cursor方法允许观察查询系统执行的操作。这个方法对于分析高效查询和决定如何使用索引进行查询是十分有用的。这个方法检测的是查询的操作,而不是查询执行时间。因为这个方法尝试多个查询计划,它并不能准确的反映出查询执行时间。
流量统计工具源码,ubuntu限制显卡功耗,爬虫下载视频电影,php即时通讯用哪种技术好学习,seo魔术排名lzw
h5棋牌游戏源码百度云,vscode安卓汉化,ubuntu 显卡插槽,tomcat7 cmd,洋参爬虫,php 关联数组 字符串,整站seo哪家售后好,wap网站跳到qq群,bootstrap 内容页模板lzw
分析查询性能
explain() cursor方法允许观察查询系统执行的操作。这个方法对于分析高效查询和决定如何使用索引进行查询是十分有用的。这个方法检测的是查询的操作,而不是查询执行时间。因为这个方法尝试多个查询计划,它并不能准确的反映出查询执行时间。
评估一个查询的性能
使用explain()方法,调用find()返回的指针的该方法即可。
例:
在type字段创建索引
db.testData.ensureIndex({‘type’:1});
评估一个在type字段上的查询。
db.testData.find({type:’food’}).explain()
结果如下:
{
“cursor” : “BtreeCursor type_1”,
“isMultiKey” : false,
“n” : 3,
“nscannedObjects” : 3,
“nscanned” : 3,
“nscannedObjectsAllPlans” : 3,
“nscannedAllPlans” : 3,
“scanAndOrder” : false,
“indexOnly” : false,
“nYields” : 1,
“nChunkSkips” : 0,
“millis” : 64,
“indexBounds” : {
“type” : [
[
“food”,
“food”
]
]
},
“server” : “TT:27017”,
“filterSet” : false
}
cursor值为BtreeCursor表名查询使用了索引。
查询返回n=3条记录。
为了返回这五条记录,查询扫描了nscanned=3条记录,然后读到了nscannedObjects=3条完整的记录,如果没有索引,将扫描所有记录。
比较索引查询性能
手动比较一个使用多个字段的查询,可以联合使用hint()和explain()方法。
例:评估使用不同字段的索引
db.testData.find({type:’food’}).hint({type:1}).explain();
结果:
{
“cursor” : “BtreeCursor type_1”,
“isMultiKey” : false,
“n” : 3,
“nscannedObjects” : 3,
“nscanned” : 3,
“nscannedObjectsAllPlans” : 3,
“nscannedAllPlans” : 3,
“scanAndOrder” : false,
“indexOnly” : false,
“nYields” : 0,
“nChunkSkips” : 0,
“millis” : 40,
“indexBounds” : {
“type” : [
[
“food”,
“food”
]
]
},
“server” : “TT:27017”,
“filterSet” : false
}
db.testData.find( { type: ‘food’ } ).hint( { type: 1, name: 1 } ).explain();
//这句话执行不成功,待解决
这些返回的统计结果忽略了使用各自的索引的执行的查询。
注意:如果不适用hint()执行explain()方法,查询优化器将重新评估查询,并且在返回查询统计之前运行多索引查询。
更详细的explain输出,查看explain-results。