Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mencari Rekod Geografi Terdekat Dalam Jejari Tertentu Menggunakan Latitud dan Longitud?

Bagaimana untuk Mencari Rekod Geografi Terdekat Dalam Jejari Tertentu Menggunakan Latitud dan Longitud?

Susan Sarandon
Lepaskan: 2025-01-18 16:07:13
asal
993 orang telah melayarinya

How to Find the Nearest Geographic Record Within a Specified Radius Using Latitude and Longitude?

Tentukan jarak dalam pangkalan data latitud dan longitud

Memandangkan koordinat latitud dan longitud, tugasnya adalah untuk mendapatkan semula rekod dengan latitud dan longitud sepadan yang terdekat daripada pangkalan data sambil memastikan jarak itu kekal dalam ambang tertentu. Jika jarak melebihi had yang ditetapkan, tiada rekod harus dikembalikan.

Struktur jadual yang disediakan termasuk lajur untuk longitud, latitud dan maklumat berkaitan lokasi lain. Untuk melakukan ini, kami menggunakan pertanyaan SQL berikut:

SELECT latitude, longitude, SQRT(
    POW(69.1 * (latitude - [startlat]), 2) +
    POW(69.1 * ([startlng] - longitude) * COS(latitude / 57.3), 2)) AS distance
FROM TableName HAVING distance < [radius]
Salin selepas log masuk

Dalam pertanyaan ini, [startlat] dan [startlng] mewakili koordinat permulaan jarak yang diukur. Pengiraan jarak dilakukan menggunakan formula Haversine, yang menentukan jarak antara dua titik pada sfera dengan tepat (dalam kes ini, Bumi). Fungsi POW() menduakan perbezaan antara koordinat permulaan dan sasaran, dan fungsi COS() mengambil kira kelengkungan Bumi. Hasil akhirnya ialah jarak dalam batu.

Dengan memasukkan klausa HAVING dengan syarat "jarak < [jejari]" kami memastikan bahawa hanya rekod yang jaraknya kurang daripada jejari [jejari] yang ditentukan dikembalikan.

Atas ialah kandungan terperinci Bagaimana untuk Mencari Rekod Geografi Terdekat Dalam Jejari Tertentu Menggunakan Latitud dan Longitud?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan