【问题标题】:Given a user's location, select rows that include that user in their radius给定用户的位置,选择在其半径内包含该用户的行
【发布时间】:2015-04-23 10:36:28
【问题描述】:

我有一个 MySQL 表,其中包含行 latitudelongituderadius。经纬度类型为DOUBLEradius 的类型为 INT,以米为单位。本质上,每一行代表地球上的一个圆圈。

给定 user_latitudeuser_longitude 的值,我如何选择所有包含该用户圈子的行?

我制作了一个快速图表来说明,以防我的问题不清楚。每个红点代表user_latitudeuser_longitude点,每个圆圈代表数据库中的latitudelongituderadius行。

【问题讨论】:

  • 您当前的查询是什么?
  • 可以使用类似 where (lat_x - $x) + (lat_y - $y) -$r 的东西。 [这是一个圆的粗略近似..]
  • 你不需要担心圆,你只需要关心点之间的距离是否小于半径
  • @pala_ 即圆的定义
  • 是的,但你不需要考虑生成圆圈。

标签: php mysql location coordinates


【解决方案1】:

step1:实现harsine距离公式

delimiter //
create function DistanceInKm(
        lat1 FLOAT, lon1 FLOAT,
        lat2 FLOAT, lon2 FLOAT
     ) returns float
    NO SQL DETERMINISTIC
begin
    return degrees(acos(
              cos(radians(lat1)) *
              cos(radians(lat2)) *
              cos(radians(lon2) - radians(lon1)) +
              sin(radians(lat1)) * sin(radians(lat2))
            )) * 111.045;
END//
delimiter ;

(幻数 111.045 将其转换为公里,英里使用 69)

第二步:使用函数

select * from areas where distance(lat, long, USERLAT, USERLONG) < radius

reference

【讨论】:

  • 感谢@pala_ 的回答,不过是一个问题。以米为单位的半径的“幻数”是多少?
  • 我猜是 111045,因为一公里就是一千米
  • 感谢您的回答,根据我目前的测试,它似乎有效:)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2013-05-23
  • 1970-01-01
  • 2011-10-22
  • 2011-12-28
  • 2016-07-09
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多