即使在索引字段上,MongoDB排序也非常慢

Ayu*_*ary 5 sorting indexing mongodb

所以我今天遇到了这个问题,我的MongoDB查询极其缓慢和超时的地方.我发布了这个问题 - MongoDB记录太多了?他的建议是对的,我必须确保索引并消除不区分大小写.我在Mongo shell中试过它,效果很好.

然而,当我通过PHP运行它时,它仍然是相同的:(然后我意识到查询对"id"(不是_id)字段进行了排序,当我删除它时,事情变得非常快.但是排序,它真的很慢.我已经在id字段上有一个索引.这是查询btw:

db.tweet_data.find({ 
...     $or: 
...         [ 
...             { in_reply_to_screen_name: /^kunalnayyar$/, handle: /^kaleycuoco$/, id: { $gt: 0 } }, 
...             { in_reply_to_screen_name: /^kaleycuoco$/, handle: /^kunalnayyar$/, id: { $gt: 0 } } 
...         ], 
...     in_reply_to_status_id_str: { $ne: null } 
...     
...     } ).sort({id:-1})explain()
Run Code Online (Sandbox Code Playgroud)

所以我的索引是:(不是复合的){ {id:-1} , {handle:1}, {in_reply_to_screen_name:1} } 经过一些阅读后,我意识到它应该是一个复合索引,我尝试了两种变化,但没有成功:1.2 {handle:1, in_reply_to_screen_name:1, id:-1} .{id:-1,handle:1, in_reply_to_screen_name:1}

我不确定我哪里出错了,但我很确定问题是在这里索引.我太嗡嗡声了,无法理解索引的顺序和字段

MrK*_*urt 1

您应该explain针对您的查询运行,它将帮助您弄清楚发生了什么。

Mongo 很可能没有使用索引来进行过滤和排序。当您使用 时$or,它可以使用多个索引来匹配选项。但是当您添加 a 时,sort它可能会使其不使用可用于过滤的索引。

当您想要对查询进行排序时,您需要确保排序字段位于您想要命中的索引中(最后一个,否则无法使用它进行排序)。

您也可以通过传递索引提示来加快速度。我不知道您的查询匹配了多少文档,但如果数量很小并且您确保初始条件命中索引,则_id可以快速完成排序。