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
Freigeben: 2024-10-29 03:55:29
Original
875 Leute haben es durchsucht

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
Nach dem Login kopieren

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)
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage