On this page
2d Indexes
在本页面
对存储为二维平面上的点的数据使用2d
索引。 2d
索引适用于 MongoDB 2.2 及更早版本中使用的传统坐标对。
在以下情况下使用2d
索引:
有关地理空间查询的更多信息,请参见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"} }
。