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

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

问题是这样的:
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)
迷茫

geohash を参照すると、より効率的になるはずです
http://www.cnblogs.com/LBSer/p/3310455.html

いいねを押す +0
刘奇

球上の2点間の距離を計算するだけで分かりますd(x1,y1,x2,y2)=r*arccos(sin(x1)*sin(x2)+cos(x1)*cos(x2)*cos(y1-y2))
距離の換算単位を加えると自分で値が分かります

いいねを押す +0
黄舟

は意味的には 1经度(纬度)= 12656米 である必要があります。ただし、これはおおよその値であり、特に経度では、緯度が高くなるほど値が小さくなります。極では値が 0 になります。

この SQL は非常に非効率であり、テーブル全体をスキャンする必要があります。 MySQL については、MySQL Spatial について学ぶことができます。 MongoDB は空間データのサポートが強化されており、GeoHash 関数が組み込まれています。

いいねを押す +0
阿神

この記事を読んだ後、問題は解決されました http://tech.meituan.com/lucene- distance....

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!