我无法使用索引优化不同的查询。
我的收藏品如下:
{
"_id" : ObjectId("592ed92296232608d00358bd"),
"measurement" : ObjectId("592ed92196232608d0034c23"),
"loc" : {
"coordinates" : [
2.65939299848366,
50.4380671935187
],
"type" : "Point"
},
"elements" : [
ObjectId("592ed92196232608d0034c24"),
ObjectId("592ed92196232608d0034c26"),
ObjectId("592ed92196232608d0034c28")
]
}
我正在尝试执行类似
的查询db.mycol.distinct('elements', {
$and:[
measurement:{
$in:[
ObjectId("592ed92196232608d0034c23"),
ObjectId("592ed92196232608d0034c24")
]
},
{
loc:{
$geoWithin:{
$geometry:{
type:'Polygon',
coordinates:[[
[
2.0214843750000004,
50.25071752130677
],
[
2.0214843750000004,
50.65294336725709
],
[
3.0487060546875004,
50.65294336725709
],
[
3.0487060546875004,
50.25071752130677
],
[
2.0214843750000004,
50.25071752130677
]
]]
}
}
}
}
]
})
我有这个索引:
{
measurement: 1,
loc: '2dsphere',
elements: 1
}
查询计划(db.mycol.explain().distinct(...)
)显示了一个IXSCAN,但查询需要很长时间。我添加了索引,希望它可以使用Mongo covered query。该文件指出
- 查询中的所有字段都是索引的一部分,
- 并且结果中返回的所有字段都在同一索引中。
所以我猜我需要一个包含elements
的索引。但是根据查询执行时间,它没有使用它。
为此类查询索引集合的最佳方法是什么?
答案 0 :(得分:1)
涵盖的查询不适用于数组。
来自问题中提到的同一页面:
索引字段的限制
如果符合以下情况,索引无法覆盖查询:
- 集合中任何文档中的任何索引字段都包含一个数组。如果索引字段是数组,则索引将成为多键索引,并且不支持覆盖的查询。