DocumentDB - Geodaten
Microsoft fügte hinzu geospatial supportHiermit können Sie Standortdaten in Ihren Dokumenten speichern und räumliche Berechnungen für Entfernungen und Schnittpunkte zwischen Punkten und Polygonen durchführen.
Geodaten beschreiben die Position und Form von Objekten im Raum.
In der Regel kann es verwendet werden, um den Standort einer Person, einen Ort von Interesse oder die Grenze einer Stadt oder eines Sees darzustellen.
Häufige Anwendungsfälle umfassen häufig Proximity-Abfragen. Zum Beispiel "Finde alle Universitäten in der Nähe meines aktuellen Standorts".
EIN Pointbezeichnet eine einzelne Position im Raum, die den genauen Ort darstellt, z. B. die Adresse einer bestimmten Universität. Ein Punkt wird in DocumentDB anhand seines Koordinatenpaars (Längen- und Breitengrad) dargestellt. Das Folgende ist ein Beispiel für einen JSON-Punkt.
{
"type":"Point",
"coordinates":[ 28.3, -10.7 ]
}
Schauen wir uns ein einfaches Beispiel an, das den Standort einer Universität enthält.
{
"id":"case-university",
"name":"CASE: Center For Advanced Studies In Engineering",
"city":"Islamabad",
"location": {
"type":"Point",
"coordinates":[ 33.7194136, -73.0964862 ]
}
}
Um den Universitätsnamen basierend auf dem Standort abzurufen, können Sie die folgende Abfrage verwenden.
SELECT c.name FROM c
WHERE c.id = "case-university" AND ST_ISVALID({
"type":"Point",
"coordinates":[ 33.7194136, -73.0964862 ] })
Wenn die obige Abfrage ausgeführt wird, erhalten Sie die folgende Ausgabe.
[
{
"name": "CASE: Center For Advanced Studies In Engineering"
}
]
Erstellen Sie ein Dokument mit Geodaten in .NET
Sie können ein Dokument mit Geodaten erstellen. Schauen wir uns ein einfaches Beispiel an, in dem ein Universitätsdokument erstellt wird.
private async static Task CreateDocuments(DocumentClient client) {
Console.WriteLine();
Console.WriteLine("**** Create Documents ****");
Console.WriteLine();
var uniDocument = new UniversityProfile {
Id = "nust",
Name = "National University of Sciences and Technology",
City = "Islamabad",
Loc = new Point(33.6455715, 72.9903447)
};
Document document = await CreateDocument(client, uniDocument);
Console.WriteLine("Created document {0} from typed object", document.Id);
Console.WriteLine();
}
Es folgt die Implementierung für die UniversityProfile-Klasse.
public class UniversityProfile {
[JsonProperty(PropertyName = "id")]
public string Id { get; set; }
[JsonProperty("name")]
public string Name { get; set; }
[JsonProperty("city")]
public string City { get; set; }
[JsonProperty("location")]
public Point Loc { get; set; }
}
Wenn der obige Code kompiliert und ausgeführt wird, erhalten Sie die folgende Ausgabe.
**** Create Documents ****
Created new document: nust
{
"id": "nust",
"name": "National University of Sciences and Technology",
"city": "Islamabad",
"location": {
"type": "Point",
"coordinates": [
33.6455715,
72.9903447
]
},
"_rid": "Ic8LAMEUVgANAAAAAAAAAA==",
"_ts": 1450200910,
"_self": "dbs/Ic8LAA==/colls/Ic8LAMEUVgA=/docs/Ic8LAMEUVgANAAAAAAAAAA==/",
"_etag": "\"00004100-0000-0000-0000-56704f4e0000\"",
"_attachments": "attachments/"
}
Created document nust from typed object