Heim >Datenbank >MySQL-Tutorial >Wie können wir überlappende Markierungsradien mithilfe von SQL identifizieren?

Wie können wir überlappende Markierungsradien mithilfe von SQL identifizieren?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-10-29 03:55:29843Durchsuche

How Can We Identify Overlapping Marker Radiuses Using SQL?

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn