Verwenden Sie Koordinaten, um nach Gebäuden in einem bestimmten Umkreis zu suchen
Bei der Verarbeitung geografischer Daten müssen Sie normalerweise Objekte in einem bestimmten Bereich eines bestimmten Standorts finden. Dies ist besonders nützlich für Aufgaben wie das Auffinden von Gebäuden in einem bestimmten Umkreis um einen bestimmten Punkt. In diesem Artikel konzentrieren wir uns darauf, alle Gebäude im Umkreis von 5 Meilen um einen bestimmten Koordinatensatz zu finden.
Datenstruktur
Unsere Datenbanktabelle trägt den Namen „Gebäude“ und enthält die folgenden notwendigen Informationen:
Herausforderung
Wir möchten alle Gebäude abrufen, die in einem 5-Meilen-Radius um einen bestimmten Punkt liegen, den wir mithilfe eines bestimmten Koordinatensatzes darstellen:
Erster Versuch
Um nach Gebäuden innerhalb des gewünschten Bereichs zu suchen, könnten wir zunächst die Verwendung der Funktion ST_Contains in Betracht ziehen. Dieser Ansatz funktioniert jedoch nur, wenn wir die Koordinaten als eine einzelne Geometrie speichern. Da wir separate Breiten- und Längengradspalten verwenden, kann ST_Contains nicht direkt angewendet werden.
Lösung
Stattdessen können wir zwei andere Funktionen nutzen, um punktbasierte Geodatenberechnungen durchzuführen: ST_DWithin und ST_Distance. Lassen Sie uns sie einzeln erkunden.
1. ST_DWithin
ST_DWithin ermöglicht uns zu überprüfen, ob sich eine Geometrie innerhalb eines bestimmten Abstands zu einer anderen Geometrie befindet. Hier ist ein Beispiel dafür, wie wir es in dieser Situation verwenden:
<code class="language-sql">SELECT name, long, lat, ST_Distance('POINT(-84.38653999999998, 33.72024)'::geography, ST_MakePoint(long, lat)) * 0.000621371 AS distance FROM building WHERE ST_DWithin('POINT(-84.38653999999998, 33.72024)'::geography, ST_MakePoint(long, lat), 8046.72); -- 8046.72 米 = 5 英里</code>
2. ST_Distance
ST_Distance Berechnet den Abstand (in Metern) zwischen zwei Geometrien. Damit können wir alle Gebäude im Umkreis von 5 Meilen finden und dann die Entfernung in Meilen umrechnen:
<code class="language-sql">SELECT name, long, lat, ST_Distance('POINT(-84.38653999999998, 33.72024)'::geography, ST_MakePoint(long, lat)) * 0.000621371 AS distance FROM building WHERE ST_Distance('POINT(-84.38653999999998, 33.72024)'::geography, ST_MakePoint(long, lat)) * 0.000621371 < 5;</code>
Beachten Sie, dass die Reihenfolge der Argumente beim Konstruieren von ST_Point-Geometrien entscheidend ist. Der erste Parameter stellt den Längengrad und der zweite Parameter den Breitengrad dar.
Wenn Sie eine dieser beiden Abfragen ausführen, sollten Sie die gewünschten Ergebnisse erhalten: eine Liste mit Gebäudenamen, Längengrad, Breitengrad und Entfernung von den angegebenen Koordinaten, gefiltert, um nur die Gebäude innerhalb eines 5-Meilen-Radius einzuschließen.
Das obige ist der detaillierte Inhalt vonWie finde ich Gebäude in einem Umkreis von 5 Meilen mithilfe von Breiten- und Längengradkoordinaten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!