我试着从给定的纬度和经度得到所有可能的纬度和经度,在一米范围内。下面是我找到的mysql查询。但是下面的一个是以公里为单位的距离。我要米。有人能帮我修改一下查询,这样我就可以直接进入特定的米范围而不是公里范围吗?
SELECT id, location_name,
(6371 * acos( cos( radians(@myLat) ) * cos( radians(latitude) ) * cos( radians(longitude) - radians(@myLng)) + sin(radians(@myLat)) * sin(radians(latitude)) )) as distance FROM sample.locations
HAVING distance <= 50
这里50公里,不是米。如何让步?在这个查询中,我不能总是将米转换成公里,因为我的数据是以米为单位的。有人能帮忙吗?
1条答案
按热度按时间eivnm1vs1#
6371是以公里为单位的地球半径。换成米。来自维基百科
地球的平均半径为6371.0088公里(3958.7613英里)。[16]
6371.0088公里=6371008.8米