$maxDistance - Amazon DocumentDB

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

$maxDistance

$maxDistanceOperator di Amazon DocumentDB digunakan untuk menentukan jarak maksimum (dalam meter) dari titik GeoJSON di mana dokumen harus berada di dalamnya untuk dimasukkan dalam hasil kueri. Operator ini digunakan bersama dengan $nearSphere operator untuk melakukan kueri geospasial.

Parameter

  • $maxDistance: Jarak maksimum (dalam meter) dari titik referensi di mana dokumen harus berada di dalamnya untuk dimasukkan dalam hasil kueri.

Contoh (MongoDB Shell)

Contoh berikut menunjukkan cara menggunakan $maxDistance operator di Amazon DocumentDB untuk menemukan semua ibu kota negara bagian dalam jarak 100 kilometer dari Boston.

Buat dokumen sampel

db.capitals.insert([ { state: "Massachusetts", city: "Boston", location: { type: "Point", coordinates: [-71.0589, 42.3601] } }, { state: "Rhode Island", city: "Providence", location: { type: "Point", coordinates: [-71.4128, 41.8239] } }, { state: "New Hampshire", city: "Concord", location: { type: "Point", coordinates: [-71.5383, 43.2067] } }, { state: "Vermont", city: "Montpelier", location: { type: "Point", coordinates: [-72.5751, 44.2604] } } ]);

Contoh kueri

db.capitals.find( { location: { $nearSphere: { $geometry: { type: "Point", coordinates: [-71.0589, 42.3601] }, $maxDistance: 100000 } } }, { state: 1, city: 1, _id: 0 } );

Keluaran

[ { "state": "Rhode Island", "city": "Providence" }, { "state": "New Hampshire", "city": "Concord" } ]

Contoh kode

Untuk melihat contoh kode untuk menggunakan $maxDistance perintah, pilih tab untuk bahasa yang ingin Anda gunakan:

Node.js
const { MongoClient } = require('mongodb'); async function findCapitalsNearBoston() { const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false'); const db = client.db('test'); const capitals = db.collection('capitals'); const result = await capitals.find({ location: { $nearSphere: { $geometry: { type: "Point", coordinates: [-71.0589, 42.3601] }, $maxDistance: 100000 } } }, { projection: { state: 1, city: 1, _id: 0 } }).toArray(); console.log(result); await client.close(); } findCapitalsNearBoston();
Python
from pymongo import MongoClient def find_capitals_near_boston(): client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false') db = client.test capitals = db.capitals result = list(capitals.find( { "location": { "$nearSphere": { "$geometry": { "type": "Point", "coordinates": [-71.0589, 42.3601] }, "$maxDistance": 100000 } } }, {"state": 1, "city": 1, "_id": 0} )) print(result) client.close() find_capitals_near_boston()