Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mendapatkan Alamat dengan Cekap dalam Julat Tertentu menggunakan MySQL?

Bagaimana untuk Mendapatkan Alamat dengan Cekap dalam Julat Tertentu menggunakan MySQL?

Susan Sarandon
Lepaskan: 2024-11-03 15:13:03
asal
310 orang telah melayarinya

How to Efficiently Retrieve Addresses within a Specified Range using MySQL?

Mengambil Alamat dengan Cekap dalam Julat Tertentu menggunakan MySQL

Untuk mendapatkan semula alamat dengan berkesan dalam radius 5 batu dari lokasi tertentu, ia adalah tidak cekap untuk mendapatkan semua 100,000 alamat dan mengira jarak di Jawa. Sebaliknya, MySQL menyediakan penyelesaian yang sesuai melalui formula Haversine.

Formula Haversine mengira jarak bulatan besar antara dua titik pada sfera, dalam kes ini, lokasi pengguna dan setiap alamat. Menggunakan formula ini, anda boleh membina pertanyaan MySQL seperti berikut:

<code class="sql">SELECT *, ( 3959 * acos( cos( radians($lat) ) * cos( radians( lat ) ) * cos( radians( lng ) - radians($lng) ) + sin( radians($lat) ) * sin( radians( lat ) ) ) ) AS distance FROM your_table HAVING distance < 5;</code>
Salin selepas log masuk

Dalam pertanyaan di atas, $lat dan $lng mewakili koordinat pengguna, manakala lat dan lng mewakili koordinat alamat. Dengan menggunakan formula Haversine, pertanyaan mengira jarak antara setiap alamat dan lokasi pengguna dan memilih hanya yang dalam lingkungan 5 batu.

Dengan menggunakan pendekatan ini, anda boleh mendapatkan semula alamat yang perlu dengan cekap. dipaparkan pada peta sambil mengelakkan tugas pengiraan yang mahal untuk mengira jarak untuk semua 100,000 alamat.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Alamat dengan Cekap dalam Julat Tertentu menggunakan MySQL?. 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