java - sql语句查询经纬度范围
ringa_lee
ringa_lee 2017-04-17 17:56:21
0
4
525

最近在做查询指定经纬度范围的数据;问题不知如何下手,于是网上找了点资料,其中有些不懂的地方希望大家能给点想法!

问题是这样的:
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是啥意思啊,怎么来的呀?如果有大神整体解释下那就更好了!!

ringa_lee
ringa_lee

ringa_lee

모든 응답(4)
迷茫

지오해시를 참고하시면 더욱 효율적일 것입니다
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.... 이 글을 읽고 문제가 해결되었습니다.

최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!