2d Indexes

在本页面

对存储为二维平面上的点的数据使用2d索引。 2d索引适用于 MongoDB 2.2 及更早版本中使用的传统坐标对

在以下情况下使用2d索引:

  • 您的数据库具有 MongoDB 2.2 或更早版本的旧版传统坐标对,并且

  • 您不打算将任何位置数据存储为GeoJSON个对象。

有关地理空间查询的更多信息,请参见Geospatial Queries

Considerations

geoNear命令和$geoNear流水线阶段要求一个集合最多*仅具有一个2d索引和/或仅一个2dsphere index,而地理空间查询运算符(例如$near$geoWithin)允许集合具有多个地理空间索引。

由于geoNear命令和$geoNear管线阶段语法都不包含位置字段,因此存在geoNear命令和$geoNear管线阶段的地理空间索引限制。这样,多个2d索引或2dsphere索引之间的索引选择是不明确的。

地理空间查询运算符没有此类限制,因为这些运算符采用了位置字段,从而消除了歧义。

如果您的位置数据包含 GeoJSON 对象,请不要使用2d索引。要同时在传统坐标对 GeoJSON objects上构建索引,请使用2dsphere索引。

分片集合时,不能将2d索引用作shard key。但是,可以通过使用其他字段作为分片键在分片集合上创建地理空间索引。

Behavior

2d索引支持对平面欧几里德平面的计算。 2d索引还支持球体(例如$nearSphere)上的仅距离计算,但是对于球体(例如$geoWithin)上的* geometric *计算,请将数据存储为GeoJSON objects并使用2dsphere索引。

2d索引可以引用两个字段。第一个必须是位置字段。 2d复合索引构造的查询首先在位置字段上选择,然后通过其他条件过滤这些结果。复合2d索引可以涵盖查询。

sparse Property

2d索引始终为sparse,而忽略sparse选项。如果文档缺少2d索引字段(或者该字段是null或空数组),则 MongoDB 不会将文档的条目添加到2d索引中。对于插入,MongoDB 插入文档,但不添加到2d索引。

对于包含2d索引键以及其他类型的键的复合索引,只有2d索引字段才能确定索引是否引用文档。

Collation Option

2d索引仅支持简单的二进制比较,不支持collation选项。

要在具有非简单排序规则的集合上创建2d索引,必须在创建索引时显式指定{collation: {locale: "simple"} }