mysql经纬度查范围内_sql语句查询经纬度范围

指定一个经纬度,给定一个范围值(单位:千米),查出在经纬度周围这个范围内的数据。

经度:113.914619

纬度:22.50128

范围:2km

longitude为数据表经度字段

latitude为数据表纬度字段

SQL在mysql下测试通过,其他数据库可能需要修改

SQL语句如下:

48304ba5e6f9fe08f3fa1abda7d326ab.png

select * from location where sqrt(

(

((113.914619-longitude)*PI()*12656*cos(((22.50128+latitude)/2)*PI()/180)/180)

*

((113.914619-longitude)*PI()*12656*cos (((22.50128+latitude)/2)*PI()/180)/180)

)

+

(

((22.50128-latitude)*PI()*12656/180)

*

((22.50128-latitude)*PI()*12656/180)

)

)<2

48304ba5e6f9fe08f3fa1abda7d326ab.png

MySQL性能调优 – 使用更为快速的算法进行距离

最近遇到了一个问题,通过不断的尝试最终将某句原本占据近1秒的查询优化到了0.01秒,效率提高了100倍.

问题是这样的,有一张存放用户居住地点经纬度信息的MySQL数据表,表结构可以简化 为:id(int),longitude(long),latitude()long. 而业务系统中有一个功能是查找离某个用户最近的其余数个用户,通过代码分析,可以确定原先的做法基本是这样的:

//需要查询的用户的坐标

$lat=20; $lon=20;//执行查询,算出该用户与所有其他用户的距离,取出最近的10个

$sql='select * from users_location order by ACOS(SIN(('.$lat.' * 3.1415) / 180 ) *SIN((latitude * 3.1415) / 180 ) +COS(('.$lat.' * 3.1415) / 180 ) * COS((latitude * 3.1415) / 180 ) *COS(('.$lon.' * 3.1415) / 180 - (longitude * 3.1415) / 180 ) ) * 6380 asc limit 10';

而这条sql执行的速度却非常缓慢,用了近1秒的时间才返回结果,应该是因为order里的子语句用了太多的数学计算公式,导致整体的运算速度下降.

而在实际的使用中,不太可能会发生需要计算该用户与所有其他用户的距离,然后再排序的情况,当用户数量达到一个级别时,就可以在一个较小的范围里进行搜索,而非在所有用户中进行搜索.

所以对于这个例子,我增加了4个where条件,只对于经度和纬度大于或小于该用户1度(111公里)范围内的用户进行距离计算,同时对数据表中的经度和纬度两个列增加了索引来优化where语句执行时的速度.

最终的sql语句如下

$sql='select * from users_location where latitude > '.$lat.'-1 and latitude < '.$lat.'+1 and longitude > '.$lon.'-1 and longitude < '.$lon.'+1 order by ACOS(SIN(('.$lat.' * 3.1415) / 180 ) *SIN((latitude * 3.1415) / 180 ) +COS(('.$lat.' * 3.1415) / 180 ) * COS((latitude * 3.1415) / 180 ) *COS(('.$lon.'* 3.1415) / 180 - (longitude * 3.1415) / 180 ) ) * 6380 asc limit 10';

经过优化的sql大大提高了运行速度,在某些情况下甚至有100倍的提升.这种从业务角度出发,缩小sql查询范围的方法也可以适用在其他地方.

转自:http://cancait.blog.163.com/blog/static/21335744201381401721826/

http://www.cnblogs.com/tyjsjl/p/3799439.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PHP中可以使用第三方库或者算法来计算给定经纬度范围内的点。具体的实现可以使用 MySQL 的空间函数或者 PHP 的第三方库,例如 geoPHP 。 如果使用 MySQL 的空间函数,你需要在数据库中存储经纬度信息并且支持空间数据类型。然后你可以使用 MySQL 的 ST_Contains() 函数来查询给定经纬度范围内的点。 如果使用第三方库,则可以使用 geoPHP 库来计算给定经纬度范围内的点。geoPHP 提供了各种函数来计算空间数据,如编码、距离计算、面积计算等。 ### 回答2: PHP经纬度查询范围是指利用PHP编程语言来查询指定经纬度范围内的数据或信息。在PHP中,我们可以利用经纬度的数值和一些特定的函数来实现这个功能。 要实现经纬度查询范围功能,首先需要明确查询范围是半径还是矩形范围。如果是半径范围,我们可以使用Haversine公式计算给定经纬度和半径的圆形范围内的地点。这个公式可以计算地球球面上两个点之间的距离。 如果是矩形范围,我们可以使用纬度和经度的最大最小值来实现。例如,我们可以定义一个矩形区域的南北边界和东西边界,然后在数据库中查询位于该矩形范围内的数据。 在PHP中,有一些常用的函数可以帮助实现这些功能。例如,我们可以使用haversine函数计算两个经纬度之间的距离,再与给定的半径进行比较,以确定是否在查询范围内。 另外,我们可以使用SQL语句查询数据库中符合条件的数据。例如,我们可以使用SELECT语句结合WHERE子句来筛选出位于特定经纬度范围内的数据。 总之,通过使用PHP中的一些特定函数和SQL查询语句,我们可以实现经纬度查询范围的功能。这可以帮助我们在地理信息系统、位置服务和其他应用中有效地查询和分析数据。 ### 回答3: PHP经纬度查询范围指的是通过PHP代码来查询特定经纬度范围内的地理点或位置。在PHP中,可以使用一些地理位置相关的库或API来实现这个功能。 一种常用的方法是通过调用第三方地理位置信息的API来实现范围查询。例如,可以使用谷歌地图的API或百度地图的API来查询指定经纬度范围内的地理位置。这些API提供了接口来传入经纬度范围参数,并返回符合条件的地理位置信息。 在PHP代码中,可以使用curl或http请求库来调用这些API,并通过传入相应的参数来查询指定经纬度范围内的地理位置。一般来说,需要传入一个矩形的边界坐标作为查询范围,在谷歌地图API中可以使用`bounds`参数,而在百度地图API中可以使用`bounds`或`bounds_ll`和`bounds_ur`参数。 通过调用API并解析返回的结果,可以获取指定经纬度范围内的地理位置数据,例如名称、经纬度、地址等信息。可以根据具体需求进一步处理这些数据,比如展示在地图上或进行其他相应的操作。 需要注意的是,不同的地图API可能有不同的查询限制和计费方式,使用前需要进行相关的了解和配置。此外,还需要确保PHP代码中网络请求相关的库已经安装和配置,并且有相应的API访问权限和密钥。 总之,通过PHP调用地图API来实现经纬度查询范围是一种常用的方法。以谷歌地图和百度地图为例,可以通过传入经纬度范围参数,获取指定范围内的地理位置信息,并进行相应的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值