亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > PostgreSQL > 正文

用PostgreSQL數(shù)據(jù)庫做地理位置app應(yīng)用

2020-03-12 23:54:50
字體:
供稿:網(wǎng)友
項目中用到了postgreSQL中的earthdistance()函數(shù)功能計算地球上兩點之間的距離,中文的資料太少了,我找到了一篇 英文的、講的很好的文章,特此翻譯,希望能夠幫助到以后用到earthdistance的同學(xué)
 
 

項目中用到了postgreSQL中的earthdistance()函數(shù)功能計算地球上兩點之間的距離,中文的資料太少了,我找到了一篇 英文的、講的很好的文章  ,特此翻譯,希望能夠幫助到以后用到earthdistance的同學(xué)。

做一個GEO應(yīng)用從來都不是一件容易的事。但是用一些身邊的開源項目就可以在幾分鐘內(nèi)輕松解決這個問題。 PostgreSQL有許多特性。是我的首選,它能夠把數(shù)據(jù)庫平臺提升到另一個層次。

一、兩種可用的選擇

當(dāng)我們想用Postgres作為GEO函數(shù)使用時,我們通常有2中選擇(據(jù)我所知):
PostGIS: 為postgreSQL提供了高級GEO函數(shù)功能。我用了它一段時間,但是它對于我的需求來說太笨重了。
Cube和Earthdistance: 這兩個拓展為輕量級的Geo關(guān)系實體提供了簡單、快速的實現(xiàn)方法。

二、為什么在數(shù)據(jù)庫服務(wù)器端做計算

這是件非常明顯的事。服務(wù)器存儲了所有的數(shù)據(jù),服務(wù)器拓展是用C/C++實現(xiàn)的,非???。為數(shù)據(jù)表做索引也能加快計算速度。

三、使用我的選擇--Cube and EarthDistance

作為開始,你應(yīng)該先建一個數(shù)據(jù)庫(我想你知道該怎么做),然后使它們能用我們的架構(gòu)。 執(zhí)行: 

復(fù)制代碼代碼如下:
CREATE EXTENSION cube;

然后執(zhí)行: 
復(fù)制代碼代碼如下:
CREATE EXTENSION earthdistance;

上面的命令創(chuàng)建了大約40個函數(shù),以后我們做數(shù)據(jù)查詢的時候就可以用了。
在我們的例子中,我創(chuàng)建了名為events的表,字段有:id(serial), name(varchar 255), lat(double), lng(double)。(別忘了~~)

 

四、計算2個坐標(biāo)之間的距離

計算2個坐標(biāo)之間的距離,我們要用到 earthdistance(lltoearth($latlngcube), lltoearth($latlng_cube)) 這個函數(shù)。 earthdistance()函數(shù)接受2組坐標(biāo)值,返回值一個以米為單位的的數(shù)值。

這能用于很多場景,比如根據(jù)某一位置找到離其最近的發(fā)生的新聞事件的列表。數(shù)據(jù)庫的操作可能就像下面這樣:

復(fù)制代碼代碼如下:

SELECT events.id events.name, eaerthdiatance(lltoearth({currentuserlat}, {currentuserlng}), llto_earth(events.lat, events.lng)) 
as distancefromcurrentlocation FROM events 
ORDER BY distancefromcurretnlocation ASC;

這將給我們一個很nice的新聞事件列表,按他們的離我們當(dāng)前位置的距離由近到遠(yuǎn)排序。第一個是離我們最近的。

五、找到某個半徑范圍內(nèi)的記錄 

Cube和Earthdiatance拓展提供的另一個偉大的函數(shù)是 earthbox(lltoearch($latlngcub), $radiusinmetres) 。 這個函數(shù)通過簡單的比較就能到找到某個半徑范圍內(nèi)的所有記錄。它是靠返回2點之間的“大圓距離”實現(xiàn)的。

 

【譯者注】大圓距離(Great circle disstance)指的是從球面的一點A出發(fā)到達(dá)球面上另一點B,所經(jīng)過的最短路徑的長度。一般說來,球面上任意兩點A和B都可以與球心確定唯一的大圓,這個大圓被稱為黎曼圓,而在大圓上連接這兩點的較短的一條弧的長度就是大圓距離。如果想了解更多,請看wiki: 大圓距離

它能用于查詢我們城市中所有的新聞事件: 

復(fù)制代碼代碼如下:
SELECT events.id, events.name FROM events WHERE earthbox({currentuserlat}, {currentuserlng}, {radiusinmetres}) @> llto_earth(events.lat, events.lng);

這條查詢語句僅僅會返回在radius_ in_ metres指定的半徑范圍內(nèi)的記錄,非常簡單吧!

 

六、提高查詢速度

你可能會發(fā)現(xiàn)上面的查詢有不小的開銷。以我的經(jīng)驗,最好對一些字段建立索引。 (下面這條語句假定你又events表, 同時events表有字段lat和lng) 
CREATE INDEX ${nameofindex} on events USING gits(lltoearth(lat, lng));

七、數(shù)據(jù)類型

我的應(yīng)用比較簡單,所以我把經(jīng)緯度(lat和lng)都設(shè)成了double類型。這使得我用Node.js開發(fā)起來更加快速,而不用再去自己定制針對GIST類型的解決方案。

八、就這些!

很神奇,對么????我們僅僅用常用的數(shù)據(jù)類型(double)就足以去用一些GEO函數(shù)創(chuàng)建基于地理位置的社交app

九、我使用的postgreSQL語句總結(jié)(使用實例):

 

復(fù)制代碼代碼如下:
/*
* postgreSQL之earthdistance學(xué)習(xí)筆記
* author: wusuopubupt
* date: 2013-03-31
*/

 

/*創(chuàng)建表*/
CREATE TABLE picture (
  id serial PRIMARY KEY ,
  p_uid char(12) NOT NULL,
  p_key char(23) NOT NULL,
  lat real not null,
  lng real NOT NULL,
  up int NOT NULL,
  down int NOT NULL,
  ip varchar(15) DEFAULT NULL,
  address varchar(256) DEFAULT NULL
);

/*插入記錄*/
INSERT INTO picture(p_uid, p_key, lat, lng, up, down, ip, address) 
VALUES('aaaabbbbcccc', '2014032008164023279.png', 40.043945, 116.413668, 0, 0, '', '');

/*插入記錄*/
INSERT INTO picture(p_uid, p_key, lat, lng, up, down, ip, address) 
VALUES('xxxxccccmmmm', '2014032008164023111.png', 40.067183, 116.415230, 0, 0, '', '');

/*選擇記錄*/
SELECT * FROM picture;

/*更新記錄*/
UPDATE picture SET address='LiShuiqiao' WHERE id=1;
UPDATE picture SET address='TianTongyuan' WHERE id=2;

/*對經(jīng)緯度列創(chuàng)建索引*/
CREATE INDEX ll_idx on picture USING gist(ll_to_earth(lat, lng));

/*根據(jù)半徑(1000米)選擇記錄*/
SELECT * FROM picture where earth_box(ll_to_earth(40.059286,116.418773),1000) @> ll_to_earth(picture.lat, picture.lng);

/*選擇距離當(dāng)前用戶的距離*/
SELECT picture.id, earth_distance(ll_to_earth(picture.lat, picture.lng), ll_to_earth(40.059286,116.418773)) 
AS dis FROM picture 
ORDER BY dis ASC;

/*
 * 以下內(nèi)容是網(wǎng)上的一篇教程
 * 地址:http://www.cse.iitb.ac.in/dbms/Data/Courses/CS631/PostgreSQL-Resources/postgresql-9.2.4/contrib/earthdistance/expected/earthdistance.out
 */
--
--  Test earthdistance extension
--
-- In this file we also do some testing of extension create/drop scenarios.
-- That's really exercising the core database's dependency logic, so ideally
-- we'd do it in the core regression tests, but we can't for lack of suitable
-- guaranteed-available extensions.  earthdistance is a good test case because
-- it has a dependency on the cube extension.
--
CREATE EXTENSION earthdistance;  -- fail, must install cube first
ERROR:  required extension "cube" is not installed
CREATE EXTENSION cube;
CREATE EXTENSION earthdistance;
--
-- The radius of the Earth we are using.
--
SELECT earth()::numeric(20,5);
     earth     
---------------
 6378168.00000
(1 row)

--
-- Convert straight line distances to great circle distances.把直線距離轉(zhuǎn)成大圓距離
--
SELECT (pi()*earth())::numeric(20,5);
    numeric     
----------------
 20037605.73216
(1 row)

SELECT sec_to_gc(0)::numeric(20,5);
 sec_to_gc 
-----------
   0.00000
(1 row)


--
-- Convert great circle distances to straight line distances.
--
SELECT gc_to_sec(0)::numeric(20,5);
 gc_to_sec 
-----------
   0.00000
(1 row)

SELECT gc_to_sec(sec_to_gc(2*earth()))::numeric(20,5);
   gc_to_sec    
----------------
 12756336.00000
(1 row)


--
-- Set coordinates using latitude and longitude.
-- Extract each coordinate separately so we can round them.
--
SELECT cube_ll_coord(ll_to_earth(0,0),1)::numeric(20,5),
 cube_ll_coord(ll_to_earth(0,0),2)::numeric(20,5),
 cube_ll_coord(ll_to_earth(0,0),3)::numeric(20,5);
 cube_ll_coord | cube_ll_coord | cube_ll_coord 
---------------+---------------+---------------
 6378168.00000 |       0.00000 |       0.00000
(1 row)

SELECT cube_ll_coord(ll_to_earth(360,360),1)::numeric(20,5),
 cube_ll_coord(ll_to_earth(360,360),2)::numeric(20,5),
 cube_ll_coord(ll_to_earth(360,360),3)::numeric(20,5);
 cube_ll_coord | cube_ll_coord | cube_ll_coord 
---------------+---------------+---------------
 6378168.00000 |       0.00000 |       0.00000
(1 row)


--
-- Test getting the latitude of a location.
--
SELECT latitude(ll_to_earth(0,0))::numeric(20,10);
   latitude   
--------------
 0.0000000000
(1 row)

SELECT latitude(ll_to_earth(45,0))::numeric(20,10);
   latitude    
---------------
 45.0000000000
(1 row)

--
-- Test getting the longitude of a location.
--
SELECT longitude(ll_to_earth(0,0))::numeric(20,10);
  longitude   
--------------
 0.0000000000
(1 row)

SELECT longitude(ll_to_earth(45,0))::numeric(20,10);
  longitude   
--------------
 0.0000000000
(1 row)


--
-- For the distance tests the following is some real life data.
--
-- Chicago has a latitude of 41.8 and a longitude of 87.6.
-- Albuquerque has a latitude of 35.1 and a longitude of 106.7.
-- (Note that latitude and longitude are specified differently
-- in the cube based functions than for the point based functions.)
--
--
-- Test getting the distance between two points using earth_distance.
--
SELECT earth_distance(ll_to_earth(0,0),ll_to_earth(0,0))::numeric(20,5);
 earth_distance 
----------------
        0.00000
(1 row)

SELECT earth_distance(ll_to_earth(0,0),ll_to_earth(0,180))::numeric(20,5);
 earth_distance 
----------------
 20037605.73216
(1 row)

--
-- Test getting the distance between two points using geo_distance.
--
SELECT geo_distance('(0,0)'::point,'(0,0)'::point)::numeric(20,5);
 geo_distance 
--------------
      0.00000
(1 row)

SELECT geo_distance('(0,0)'::point,'(180,0)'::point)::numeric(20,5);
 geo_distance 
--------------
  12436.77274
(1 row)


--
-- Test getting the distance between two points using the <@> operator.
--
SELECT ('(0,0)'::point <@> '(0,0)'::point)::numeric(20,5);
 numeric 
---------
 0.00000
(1 row)

SELECT ('(0,0)'::point <@> '(180,0)'::point)::numeric(20,5);
   numeric   
-------------
 12436.77274
(1 row)


--
-- Test for points that should be in bounding boxes.
--
SELECT earth_box(ll_to_earth(0,0),
       earth_distance(ll_to_earth(0,0),ll_to_earth(0,1))*1.00001) @>
       ll_to_earth(0,1);
 ?column? 
----------
 t
(1 row)

SELECT earth_box(ll_to_earth(0,0),
       earth_distance(ll_to_earth(0,0),ll_to_earth(0,0.1))*1.00001) @>
       ll_to_earth(0,0.1);
 ?column? 
----------
 t
(1 row)


--
-- Test for points that shouldn't be in bounding boxes. Note that we need
-- to make points way outside, since some points close may be in the box
-- but further away than the distance we are testing.
--
SELECT earth_box(ll_to_earth(0,0),
       earth_distance(ll_to_earth(0,0),ll_to_earth(0,1))*.57735) @>
       ll_to_earth(0,1);
 ?column? 
----------
 f
(1 row)

SELECT earth_box(ll_to_earth(0,0),
       earth_distance(ll_to_earth(0,0),ll_to_earth(0,0.1))*.57735) @>
       ll_to_earth(0,0.1);
 ?column? 
----------
 f
(1 row)

 


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
精品国产av一区二区| 免费无码国产v片在线观看| 黄色片免费在线| 久久视频www| √天堂中文官网8在线| 成人看片爽爽爽| 妞干网在线观看| 97人人做人人人难人人做| 国产一级片子| 亚洲最新av在线网站| www国产精品com| 性活交片大全免费看| 91精品国产高清久久久久久91裸体| 超碰色偷偷男人的天堂| 一区二区三区四区不卡| 中文字幕一区二区三区av| 无码少妇精品一区二区免费动态| 91xxx在线观看| 国产sm调教视频| 亚洲一区免费在线观看| 另类小说视频一区二区| 一道精品视频一区二区三区图片| 精品久久99| 欧美国产日韩二区| 久久艳妇乳肉豪妇荡乳av| 国内外免费激情视频| 337p粉嫩大胆色噜噜噜噜亚洲| 国产三级av在线播放| 91野花视频| 国产色产综合色产在线视频| 日本久久综合| 国产成人综合一区二区三区| 五月天婷婷视频| 亚洲电影欧美电影有声小说| 一本大道av伊人久久综合| 一区二区日韩| 欧美精品亚州精品| 亚洲男人天堂2020| 亚洲福利一区二区| 久久先锋影音av| 欧美一区二区在线| 男生女生差差差的视频在线观看| 好吊视频一区二区三区| 久久婷婷五月综合| 精品捆绑美女sm三区| 91精品国产亚洲| 国产美女作爱全过程免费视频| 啦啦啦啦免费高清视频在线观看1| 精品亚洲一区二区三区在线观看| 台湾佬中文娱乐网欧美电影| 囯产精品一品二区三区| 岳乳丰满一区二区三区| 欧美精品福利视频| 日本黄色免费网址| 黄色在线网站噜噜噜| 精品乱码一区内射人妻无码| 国产91丝袜在线观看| 色综合色综合色综合色综合| 亚洲国产精品久久人人爱| 人人爱人人爽| 精品无码m3u8在线观看| 精品一区二区三区电影| 亚洲精品国产日韩| 亚洲免费毛片| 老师我好爽再深一点的视频| 全亚洲第一av番号网站| 日韩精品一二三| 久久99久久精品欧美| 91精品国产入口| 999www成人| 欧美日本亚洲视频| 日本在线观看网站| 国产精品专区在线| 波多野结衣久草一区| 黄色aaa视频| 99中文视频在线| 午夜性爽视频男人的天堂| 久久欧美在线电影| 在线国产福利网站| 日本国产精品视频| 亚洲成年人电影在线观看| 色综合天天天天做夜夜夜夜做| 国产成人综合一区二区三区| 91日韩在线播放| 精品一区二区三区免费观看| 国产精品午夜av在线| 欧美在线观看视频在线| 97超碰资源站| 超碰人人人人人人| 欧美精品做受xxx性少妇| 国产欧美精品区一区二区三区| 亚洲欧美日韩三级| 日韩国产一级片| 91好吊色国产欧美日韩在线| 午夜精品理论片| 色撸撸在线观看| 久久一级黄色片| 亚洲视频欧美视频| 国产精品探花视频| av资源一区二区| 欧美在线网站| 国产一区二区福利视频| 国产成人在线视频网站| 一个人www欧美| 国产成人亚洲欧洲在线| 无人区在线高清完整免费版 一区二| 精品久久久久久久久久久国产字幕| 久久一区二区三区超碰国产精品| 成年人在线免费观看| 国产女同在线观看| 91精品人妻一区二区| 亚洲成人动漫精品| 天天av天天翘天天综合网| 国产精品伦理一区二区三区| 国产熟人av一二三区| 正在播放国产一区| 91精品国产色综合| 在线播放av片| 国产三级理论片| 亚洲色图另类小说| 国产精品久久久久久久久久久久午夜片| 日韩av影片在线观看| 久久婷婷蜜乳一本欲蜜臀| 欧美成人精品二区三区99精品| 免费亚洲一区| 欧美日韩国产在线看| 国产精品成人va在线观看| 亚洲一级av无码毛片精品| 国模私拍视频在线播放| 欧美在线观看网站| 久久男人资源站| 欧美大片大片在线播放| 色偷偷av亚洲男人的天堂| 亚洲精品一区二区三区四区高清| 精品国产一区二区三区四| 麻豆免费网站| 午夜羞羞视频| 最近2018中文字幕免费在线视频| 91香蕉国产线在线观看| 久久99精品国产.久久久久| 色狠狠av一区二区三区| 日韩av片在线免费观看| 日韩精品一区二区三区| 黄色99视频| 男人午夜天堂| 久久夜精品va视频免费观看| 丝袜国产免费观看| 欧美男男激情freegay| 91性高潮久久久久久久| 天天操夜夜操av| 欧美一区二区三级| 青青青爽在线视频免费观看| 成人免费在线视频| 欧美视频在线观看一区二区三区| 国产一区二区网站| 欧美牲交a欧美牲交| 久久人人爽爽爽人久久久| 思99热精品久久只有精品| 国产欧美日韩精品一区| 欧美激情久久久久久久久久久| 宅男噜噜99国产精品观看免费| 日韩激情片免费| 亚洲欧美日韩精品一区二区| 欧洲视频在线免费观看| 亚洲综合丝袜美腿| 中文字幕在线观看亚洲| 亚洲男女毛片无遮挡| 四虎永久免费影库二三区| 一本色道久久88综合亚洲精品ⅰ| 亚洲欧美激情视频在线观看一区二区三区| 日本一区二区三区播放| 久久久久久久久久久电影| 黄色一级视频网站| 国产女人水真多18毛片18精品| 美女免费视频一区| 亚洲天堂av在线| 国产在线免费视频| 蜜桃在线一区二区| xfplay每日更新av资源在线| 久久香蕉视频网站| 99re这里只有精品6| 亚洲精品视频网上网址在线观看| 久久精品视频2| 日韩伦理一区二区三区| 丝袜中文在线| 国产精品538一区二区在线| 欧美成人第一页| 国产一区视频在线观看免费| 神马久久久久久久久久久| 亚洲成人在线| 亚洲一级免费视频| 欧美影院一区二区| 亚洲蜜臀av乱码久久精品| 成人做爽爽免费视频| 国产精品久久久久久av公交车| 色诱av手机版| 午夜剧场成人观在线视频免费观看| 欧美a∨亚洲欧美亚洲| 欧美精品hd| 久久久久青草大香线综合精品| 菠萝蜜网站在线观看| 欧美在线亚洲综合一区| 欧美巨大丰满猛性社交| 亚洲天堂在线视频观看| 国产成人激情av| 999精品在线视频| 欧美性69xxxx肥| 欧美性猛交xxxx乱大交退制版| 18被视频免费观看视频| 欧美高清一级片在线观看| 日本vs亚洲vs韩国一区三区二区| 久久久久久久久久久久网站| 成人做爰高清视频网站| 中文字幕在线观看不卡视频| 任我爽在线视频精品一| 日韩不卡在线播放| 三叶草欧洲码在线| 91成人福利视频| 污视频网站免费在线观看| 国产青春久久久国产毛片| 午夜伦理一区二区| 国产日产一区二区三区| 91精品在线观看入口| 五月天亚洲一区| 亚洲日本va在线观看| 免费97视频在线精品国自产拍| 制服丝袜中文字幕在线| 亚洲午夜久久久久久久久| 台湾佬中文在线| 欧美色婷婷天堂网站| 国产jizz18女人高潮| 91国产美女视频| 国产91色在线|亚洲| 操一操视频一区| 最近中文字幕免费mv2018在线| 嫩草www视频在线观看高清| 午夜免费福利网站| 午夜啪啪小视频| 亚洲精品国产成人影院| 国产视频在线观看网站| 97精品人妻一区二区三区蜜桃| www.老鸭窝.com| 两个人看的无遮挡免费视频| 国产精品理论在线观看| 美女精品视频| 亚洲精品第一国产综合野| 外国精品视频在线观看| 日本五十路女优| 黄色一级视频免费看| 中文字幕av资源一区| 欧美国产在线一区| 国产又色又爽又高潮免费| 欧美日韩和欧美的一区二区| 99在线小视频| 欧洲一区二区视频| 制服丝袜激情欧洲亚洲| 91在线观看网站| 欧美一级片免费在线观看| 欧美日韩亚洲一区二区| 青娱乐精品视频| 欧美极品少妇videossex| 91九色国产视频| 18深夜在线观看免费视频| 亚洲欧美日韩一区二区| 超碰在线12| 亚洲精品日韩成人| 青草视频在线观看视频| 日韩精品中文字幕吗一区二区| 国产主播色在线| 成人信息集中地欧美| 日韩精品一级二级| 色综合久久99| 国产精品久久色| 黄色三级视频片| 91视频你懂的| 欧美视频网址| 国产综合色区在线观看| 激情综合色综合啪啪开心| 亚洲激情自拍偷拍| 国语对白做受xxxxx在线中国| 成人高h视频在线| h视频在线免费看| 国产馆av播放| 国产精品免费一区二区三区在线观看| 免费大秀视频在线播放| 国产色一区二区| 免费黄色片在线观看| 波多野结衣久久久久| 欧美日韩免费观看一区二区三区| 国产人妻一区二区| 久久久国产精品无码| 性欧美一区二区| 国产成人精品免费网站| 国产一区二区三区四区五区在线| 亚洲一级免费在线观看| 91香蕉视频在线观看视频| 在线播放亚洲精品| 久久久精品视频免费观看| 黄色在线一区| 美女一区2区| 国产午夜亚洲精品午夜鲁丝片| 激情亚洲一区二区三区四区| 黄色成人在线网址| 欧美亚洲高清| 成人欧美一区二区三区在线观看| 国产成人a人亚洲精品无码| 黄色成人免费观看| 成人在线免费观看网站| 91青青在线视频| 亚洲免费影视| 精品二区久久| 国产精品精品软件视频| 少妇人妻好深好紧精品无码| 成人精品高清在线| 国产福利第一页| 日韩av在线播放资源| 五月婷婷六月婷婷| 女人香蕉久久**毛片精品| 最新一本之道波多野结衣| 91丨九色丨蝌蚪丨少妇在线观看| 欧美wwwwww| 亚洲高清国产精品| 亚洲天天影视| 国产精品欧美综合在线| 久久国产精品偷| k8久久久一区二区三区| 国产精品资源站| 亚洲图片小说区|