【发布时间】:2014-07-03 14:47:56
【问题描述】:
我有一个表格,其中包含带有坐标(纬度、经度)的本地企业 我需要获取给定半径内的所有企业,为此我使用了一个实时计算距离的查询
select b.* from `businesses` as b
where
(
1.609344 * 3956 * 2 * ASIN(
SQRT(
POWER(SIN((lat - b.lat) * pi()/180 / 2), 2) +
COS(lat * pi()/180) * COS(b.lat * pi()/180) *
POWER(SIN((lng -b.lng) * pi()/180 /-2), 2)
)
)
) <= radius
现在我需要扩大半径,以防该地区的企业太少, 所以假设在给定的半径内只有 10 家企业,我需要动态扩大半径,直到我得到 50
【问题讨论】:
-
你能去掉 WHERE 子句中的
-
但如果超过 50 个,我需要全部查看。
-
哦,我明白了……在 SQL Server 中,我可能会使用递归 CTE 来处理类似的事情,但我认为 MySQL 中没有类似的构造。在您的情况下,我可能会做的是创建一个带有临时表的存储过程,并用第一个结果填充它。如果它小于 50,那么我会在查询中循环增加半径,直到有 50,然后返回那个临时表。
标签: php mysql sql geolocation