我有一个包含坐标(lat, lon)的本地企业的表我需要获得给定半径内的所有企业,为此,我使用一个查询来计算飞行中的距离
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
只需计算到给定点的距离并使用它来排序,然后将结果的数量限制为50。
如果你想要超过50个结果,如果在那个半径内立即有超过50个结果,那就有点棘手了。
在这种情况下,你可以使用'if distance <? OR RowNum <50的。在MySQL中,创建行号的唯一方法是使用变量。
它看起来像这样:
WITH t1 AS
(
SELECT b.*,
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)
)
)
) AS distance
FROM businesses as b
), t2 AS
(
SELECT *, @rownum := @rownum + 1 AS row_num
FROM t1, (SELECT @rownum := 0) r
ORDER BY distance
)
SELECT * FROM t2
WHERE distance < ? OR row_num < ?