本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
$geometry
Amazon DocumentDB 中的$geometry運算子用於指定 GeoJSON 幾何物件做為地理空間查詢的一部分。此運算子會與其他地理空間查詢運算子搭配使用,例如 $geoWithin和 $geoIntersects,以對您的資料執行空間查詢。
在 Amazon DocumentDB 中,$geometry運算子支援下列 GeoJSON 幾何類型:
-
點 (Point)
-
LineString
-
多邊形
-
MultiPoint
-
MultiLineString
-
MultiPolygon
-
GeometryCollection
參數
-
type:GeoJSON 幾何物件的類型,例如 、PointPolygon等。 -
coordinates:代表幾何的座標陣列。座標陣列的結構取決於幾何類型。
範例 (MongoDB Shell)
下列範例示範如何使用 $geometry運算子在 Amazon DocumentDB 中執行$geoIntersects查詢。
建立範例文件
db.locations.insertMany([ { "_id": 1, "name": "Location 1", "location": { "type": "Point", "coordinates": [-73.983253, 40.753941] } }, { "_id": 2, "name": "Location 2", "location": { "type": "Polygon", "coordinates": [[ [-73.998427, 40.730309], [-73.954348, 40.730309], [-73.954348, 40.780816], [-73.998427, 40.780816], [-73.998427, 40.730309] ]] } } ]);
查詢範例
db.locations.find({ "location": { "$geoIntersects": { "$geometry": { "type": "Polygon", "coordinates": [[ [-73.998, 40.730], [-73.954, 40.730], [-73.954, 40.781], [-73.998, 40.781], [-73.998, 40.730] ]] } } } })
輸出
[
{
"_id": 2,
"name": "Location 2",
"location": {
"type": "Polygon",
"coordinates": [
[
[-73.998427, 40.730309],
[-73.954348, 40.730309],
[-73.954348, 40.780816],
[-73.998427, 40.780816],
[-73.998427, 40.730309]
]
]
}
}
]
程式碼範例
若要檢視使用 $geometry命令的程式碼範例,請選擇您要使用的語言標籤: