MongoDB如何优化查询性能?

 我来答
清宁时光17
2022-06-04 · TA获得超过1.5万个赞
知道大有可为答主
回答量:7952
采纳率:100%
帮助的人:51.7万
展开全部
站在用户的视角来看,如果一个搜索返回时间大于了1秒,就会让很多用户失去耐心。所以作为开发者而言,在开发过程中100%会遇到的一个问题就是优化数据的查询性能。那么在Mongo中是如何做查询性能优化呢?下面就给大家介绍一下。

在mongo中也提供了一个explain()方法,该方法能够提供大量与查询相关的信息。对于速度比较慢的查询来说,它是最重要的性能分析工具之一。通过查看一个查询的explain()输出信息,可以知道查询使用了哪个索引,以及是如何使用的。对于任意查询,都可以在最后添加一个explain()调用(与调用sort()或者limit()一样,不过explain()必须放在最后)。

      最常见的explain()输出有两种类型:使用索引的查询和没有使用索引的查询。其输出的信息可能如图1:

返回信息详细介绍:

“millis”表明了这个查询的执行时间。数字越小,则说明这个查询的效率越高。

“n”则表明了实际返回的文档数量。

“nscanned“描述了MongoDB在执行这个查询时搜索了多少文档。

”cursor“本查询返回值为”BasicCursor“则说明该查询未使用索引,所以才会搜索了所有的文档。如返回”BtreeCursor“则表示查询中使用了索引。

”isMultiKey“用于说明是否使用了多键索引。

”nYield“指本次查询暂停的次数。在查询期间,如果有与入请求需要处理,为了让写入请求能够顺利执行,查询会周期性的释放它的锁。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式