MongoDB CRUD操作:地理位置查询
文章目录
MongoDB支持地理空间数据的查询,这是MongoDB数据库有别于其它数据库的特色之一,在进行GIS相关系统开发的时候会比较有帮助。本文重点介绍MongoDB的地理空间功能。
地理空间数据
在MongoDB中,可以将地理空间数据存储为GeoJSON对象或传统坐标对。
GeoJSON对象
要计算类地球体上的几何形状,可将位置数据存储为GeoJSON对象,GeoJSON对象是一个内嵌文档:
- 名为 type 的字段,指定 GeoJSON对象类型
- 名为坐标的字段,用于指定对象的坐标。
<field>: {
type: <GeoJSON type> , coordinates: <coordinates> }
注意:
经纬度坐标的第一个元素是经度第二个元素是纬度。其中经度值介于-180和180之间(含)。有效的纬度值介于-90和90之间(含)。
例如,一个GeoJSON的点:
location: {
type: "Point",
coordinates: [-73.856077, 40.848447]
}
关于对GeoJSON对象的地理空间查询在球体上计算,MongoDB 使用WGS84参考系统对GeoJSON对象进行地理空间查询。
传统坐标对
要计算欧几里得平面上的距离,需将位置数据存储为传统坐标对并使用2d索引。如果手动将数据转换为GeoJSON点类型,MongoDB将通过使用2dsphere索引支持传统坐标对上的球面计算。
要将数据指定为传统坐标对,可以使用数组(首选)或嵌入式文档。
通过数组指定(首选)
<field>: [ <x>, <y> ]
指定经纬度坐标时,则指定经度,再指定纬度。
<field>: [<longitude>, <latitude> ]
- 有效的经度值介于 -180 和 180 之间(包含)。
- 有效的纬度值介于 -90 和 90 之间(包含)。
通过嵌入文档指定
<field>: {
<field1>: