Rumah > pangkalan data > tutorial mysql > Bagaimana Mengira Jarak Antara Dua Titik Menggunakan Latitud dan Longitud?

Bagaimana Mengira Jarak Antara Dua Titik Menggunakan Latitud dan Longitud?

Barbara Streisand
Lepaskan: 2024-10-29 01:56:02
asal
312 orang telah melayarinya

How to Calculate Distance Between Two Points Using Latitude and Longitude?

Mengira Jarak Diberi Dua Titik: Latitud dan Longitud

Menentukan jarak antara titik menggunakan latitud dan longitudnya ialah tugas GIS biasa. Untuk mencari titik dalam jejari tertentu, kami boleh memanfaatkan formula matematik dan pertanyaan SQL.

Formula untuk Pengiraan Jarak

Satu pendekatan ialah menggunakan formula Haversine, yang mengira jarak antara dua titik pada sfera:

<code class="python">def get_distance(lat1, lon1, lat2, lon2, unit='Mi'):
    theta = lon1 - lon2
    distance = (math.sin(math.radians(lat1)) * math.sin(math.radians(lat2))) + \
              (math.cos(math.radians(lat1)) * math.cos(math.radians(lat2)) * \
              math.cos(math.radians(theta)))
    distance = math.acos(distance)
    distance = math.degrees(distance)
    distance = distance * 60 * 1.1515
    if unit == 'Km':
        distance = distance * 1.609344
    return round(distance, 2)</code>
Salin selepas log masuk

SQL Query for Radius Search

Pilihan lain ialah menggunakan pertanyaan MySQL dengan formula jarak:

<code class="sql">SELECT *,
(((acos(sin((".$latitude."*pi()/180)) * sin((`Latitude`*pi()/180))+cos((".$latitude."*pi()/180)) * cos((`Latitude`*pi()/180)) * cos(((".$longitude."- `Longitude`)* pi()/180))))*180/pi())*60*1.1515) as distance
FROM `MyTable` HAVING distance >= ".$distance.";</code>
Salin selepas log masuk

Dengan menggunakan kaedah ini, anda boleh mengira jarak antara titik dengan cekap dan mencarinya dalam radius yang dikehendaki dari lokasi tertentu.

Atas ialah kandungan terperinci Bagaimana Mengira Jarak Antara Dua Titik Menggunakan Latitud dan Longitud?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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