Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mencari Latitud dan Longitud Terdekat dalam Jarak Tertentu Menggunakan SQL?

Bagaimana untuk Mencari Latitud dan Longitud Terdekat dalam Jarak Tertentu Menggunakan SQL?

Patricia Arquette
Lepaskan: 2025-01-18 16:17:08
asal
474 orang telah melayarinya

How to Find the Nearest Latitude and Longitude within a Given Distance Using SQL?

Pertanyaan untuk mencari latitud dan longitud terdekat menggunakan SQL

Artikel ini akan meneroka cara menggunakan SQL untuk mendapatkan longitud dan latitud terdekat dalam julat tertentu koordinat rujukan yang diberikan daripada pangkalan data.

Penerangan masalah:

Anda tahu nilai latitud dan longitud dan ingin mengekstrak rekod dalam pangkalan data yang paling sepadan dengan latitud dan longitud. Tetapi terdapat ambang jarak: jika jarak yang dikira melebihi ambang ini, tiada data harus diambil.

Struktur jadual:

列名 数据类型
id 整数
纬度 十进制
经度 十进制
地名 字符串
城市 字符串
国家 字符串
字符串
邮编 整数
海拔 整数

Pernyataan pertanyaan:

Untuk menyelesaikan tugas ini, kami menggunakan pertanyaan SQL berikut:

<code class="language-sql">SELECT 纬度, 经度, SQRT(
    POW(69.1 * (纬度 - [startlat]), 2) +
    POW(69.1 * ([startlng] - 经度) * COS(纬度 / 57.3), 2)) AS distance
FROM 表名称 HAVING distance < 25
ORDER BY distance ASC;</code>
Salin selepas log masuk
  • [startlat]: Memulakan latitud untuk pengukuran jarak.
  • [startlng]: Longitud permulaan untuk pengukuran jarak.
  • 25: Ambang jarak maksimum yang dibenarkan dalam kilometer.

Arahan:

Pertanyaan ini menggunakan formula jarak bulatan hebat untuk mengira jarak antara koordinat rujukan ([startlat], [startlng]) dan setiap rekod dalam jadual. Jika jarak yang dikira kurang daripada ambang yang ditentukan (25 kilometer dalam contoh ini), rekod akan dimasukkan dalam keputusan. Pertanyaan juga mengisih keputusan dalam tertib menaik berdasarkan jarak, memastikan rekod terdekat dikembalikan dahulu.

Atas ialah kandungan terperinci Bagaimana untuk Mencari Latitud dan Longitud Terdekat dalam Jarak Tertentu Menggunakan SQL?. 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