我在本地服务器上有一个MySQL表。该表格包含用户标记的地点的纬度和经度。我试图让所有身份标识的人在距离提供的经度和纬度1公里内标记他们的位置。但我的结果并不是预期的。如何从提供的纬度和长度从MySql获取半径范围内的所有结果查询
表:map_locations
id user_id lat lng place_name
1 1 28.584688 77.31593 Sec 2, Noida
2 2 28.596026 77.314494 Sec 7, Noida
3 5 28.579876 77.356131 Sec 35, Noida
4 1 28.516831 77.487405 Surajpur, Greater Noida
5 1 28.631451 77.216667 Connaught Place, New Delhi
6 2 19.098003 72.83407 Juhu Airport, Mumbai
,这里是PHP脚本
$lat = '28.596026';
$long = '77.314494';
$query = "SELECT id,
(6371 * acos(cos(radians($lat)) * cos(radians('lat')) *
cos(radians('lng') - radians($long)) +
sin(radians($lat)) * sin(radians('lat')))
) as distance
FROM map_locations
HAVING 'distance' < 1
ORDER BY id
LIMIT 25";
$_res = mysqli_query($conn, $query) or die('Error query: '.$query);
$detail = array();
$i=0;
while($row = $_res->fetch_assoc()) {
$detail[$i] = $row['id'];
$i++;
}
print_r($detail);
结果:
Array
(
[0] => 1
[1] => 2
[2] => 3
[3] => 4
[4] => 5
[5] => 6
)
查询返回表中的所有记录。任何人都可以让我知道查询中有什么问题吗?
是否有可能,所有记录都位于同一位置或1公里内,因为您的查询看起来很完美 –
请考虑做一个行计数,以便知道是否有任何结果。 – Script47
@JayminNoob不可能,所有记录都不在1公里以内。 –