Heim >Datenbank >MySQL-Tutorial >Wie können wir überlappende Markierungsradien mithilfe von SQL identifizieren?
Bestimmung überlappender Markierungen innerhalb des Radius
Um Personen zu identifizieren, die in überlappende Markierungsradien fallen, nutzen wir geometrische Prinzipien und wandeln Entfernungen aus Konsistenzgründen in Kilometer um .
Die Gleichung für einen Punkt (x, y) innerhalb eines Kreises mit Mittelpunkt (x1, y1) und Radius r lautet:
(x - x1)^2 + (y - y1)^2 <= r^2
Da Grad mit der Formel in Kilometer umgerechnet werden 1 Grad = 111,12 km, die Gleichung lautet:
((x - x1) * 111.12)^2 + ((y - y1) * 111.12)^2 = 4 (for radius = 2km)
Mit dieser Gleichung kann die SQL-Anweisung zum Abrufen von Ergebnissen, die beliebige Markierungsradien überlappen, wie folgt formuliert werden:
<code class="sql">SELECT A.user_id, A.radius_id, A.latitude, A.logitude FROM UserA AS A, (SELECT user_id, latitude, longitude FROM UserB WHERE user_id = 8) AS B WHERE (POW((A.latitude - B.latitude) * 111.12, 2) + POW((A.longitude - B.longitude) * 111.12, 2)) <= 4</code>
In In dieser Abfrage werden die Datensätze von BenutzerA durch Tabelle A und die Datensätze von BenutzerB mit der ID 8 durch Tabelle B dargestellt. Die Funktion POW() potenziert eine Zahl und wird hier verwendet, um die Differenz zwischen Koordinaten zu quadrieren.
Das obige ist der detaillierte Inhalt vonWie können wir überlappende Markierungsradien mithilfe von SQL identifizieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!