栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用WHERe子句在距经度和纬度的距​​离范围内找到POI

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用WHERe子句在距经度和纬度的距​​离范围内找到POI

问题是您不能

distance
select
or
where
子句中引用别名列(在这种情况下)。例如,您不能执行以下操作:

select a, b, a + b as NewCol, NewCol + 1 as AnotherCol from tablewhere NewCol = 2

这将在以下两个方面均失败:

select
尝试处理时的语句
NewCol + 1
以及
where
尝试处理时的语句
NewCol = 2

有两种方法可以解决此问题:

1)将参考值替换为计算值本身。例子:

select a, b, a + b as NewCol, a + b + 1 as AnotherCol from tablewhere  a + b = 2

2)使用外部

select
语句:

select a, b, NewCol, NewCol + 1 as AnotherCol from (    select a, b, a + b as NewCol from table) as Swhere NewCol = 2

现在,考虑到您的计算量很大而不是非常人性化的列:)我想您应该选择最后一种选择来提高可读性:

SET @orig_lat=55.4058;  SET @orig_lon=13.7907; SET @dist=10;SELECt * FROM (  SELECt     *,     3956 * 2 * ASIN(SQRT(POWER(SIN((@orig_lat -abs(latitude)) * pi()/180 / 2), 2)     + COS(@orig_lat * pi()/180 ) * COS(abs(latitude) * pi()/180)     * POWER(SIN((@orig_lon - longitude) * pi()/180 / 2), 2) )) as distance   FROM geo_kulplex.sweden_bobo) AS SWHERe distance < @distORDER BY distance limit 10;

编辑: 正如下面提到的@Kaii,这将导致全表扫描。根据要处理的数据量,您可能希望避免这种情况,而是选择第一个选项,该选项应能更快地执行。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/373129.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号