大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全家桶1年46,售后保障稳定
最近在做查询指定经纬度范围的数据;问题不知如何下手,于是网上找了点资料,其中有些不懂的地方希望大家能给点想法!
问题是这样的:
sql语句查询经纬度范围
指定一个经纬度,给定一个范围值(单位:千米),查出在经纬度周围这个范围内的数据。
经度:113.914619
纬度:22.50128
范围:2km
longitude为数据表经度字段
latitude为数据表纬度字段
SQL在mysql下测试通过,其他数据库可能需要修改
SQL语句如下:
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
其中的12656是啥意思啊,怎么来的呀?如果有大神整体解释下那就更好了!!
可以参考一下geohash,效率应该更高
http://www.cnblogs.com/LBSer/p/3310455.html
算一下球面两点距离就知道了,就是一个公式
d(x1,y1,x2,y2)=r*arccos(sin(x1)*sin(x2)+cos(x1)*cos(x2)*cos(y1-y2))
加上距离的换算单位,自己就能知道那个值了
从语义来看应该是
1经度(纬度)= 12656米
。不过这只是近似值,尤其对经度来说,纬度越高的地方这个值越小,极端情况就是在极点为0。
这条sql的效率极低,需要扫描整张表。可以考虑使用空间索引,MySQL的话,可以了解下
MySQL Spatial
。MongoDB对空间数据的支持比较好,内置了
GeoHash
功能。
当初看了这篇文章,问题就解决了 http://tech.meituan.com/lucene-distance….
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/206660.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...