SQL:动态扩展搜索条件

时间:2014-07-03 14:47:57

标签: php mysql sql geolocation

我有一张包含坐标(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

1 个答案:

答案 0 :(得分:1)

只需计算给定点的距离并使用此按钮进行订购,然后将结果数量限制为50.

如果你想要超过50个结果,如果在那个半径内立即超过50个,那将会有点棘手。

在这种情况下,你可以做一个像&#39;如果距离&lt; ?或RowNum&lt; 50&#39 ;.在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 < ?