MySQL Longitud dan Pertanyaan Latitud untuk Baris Dalam Radius X Batu
Dalam pangkalan data besar yang mengandungi data geospatial, selalunya perlu untuk mendapatkan semula baris yang berada dalam radius tertentu lokasi tertentu. Ini biasanya dicapai menggunakan geometri sfera untuk mengira jarak antara dua titik pada sfera.
Satu pertanyaan sedemikian untuk mencari baris dalam radius 25 batu dari titik tengah mengembalikan beberapa hasil yang tidak tepat, dengan jarak antara 86 hingga 800 batu dari sasaran. Berikut ialah pertanyaan asal:
<code class="sql">SELECT *,(((acos(sin(($lat*pi()/180)) * sin((`latitude`*pi()/180))+cos(($lat*pi()/180)) * cos((`latitude`*pi()/180)) * cos((($lon - `longitude`)*pi()/180))))*180/pi())*60*1.1515) AS `distance` FROM `geo_locations` HAVING `distance` < 25 ORDER BY `distance` ASC</code>
Untuk menangani isu ini, mari kita ubah suai pertanyaan berdasarkan penyelesaian yang telah berjaya dilaksanakan dalam aplikasi pencari kedai:
<code class="sql">SELECT `id`, ( 6371 * acos( cos( radians( :lat ) ) * cos( radians( `lat` ) ) * cos( radians( `long` ) - radians( :long ) ) + sin(radians(:lat)) * sin(radians(`lat`)) ) ) `distance` FROM `location` HAVING `distance` < :distance ORDER BY `distance` LIMIT 25</code>
Dalam semakan ini pertanyaan:
Dengan menggunakan pertanyaan yang dikemas kini ini, anda boleh dapatkan semula baris dengan berkesan dalam radius batu yang ditentukan di sekitar lokasi pusat tertentu.
Atas ialah kandungan terperinci ## Bagaimana untuk Membuat Pertanyaan dengan Tepat untuk Baris MySQL Dalam Jejari Batu Ditentukan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!