为不同的使用覆盖查询建立索引

时间:2017-06-13 13:36:35

标签: mongodb indexing distinct-values

我无法使用索引优化不同的查询。

我的收藏品如下:

{
        "_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的索引。但是根据查询执行时间,它没有使用它。

为此类查询索引集合的最佳方法是什么?

1 个答案:

答案 0 :(得分:1)

涵盖的查询不适用于数组。

来自问题中提到的同一页面:

  

索引字段的限制

     

如果符合以下情况,索引无法覆盖查询:

     
      
  • 集合中任何文档中的任何索引字段都包含一个数组。如果索引字段是数组,则索引将成为多键索引,并且不支持覆盖的查询。
  •