婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 用PostgreSQL數據庫做地理位置app應用

用PostgreSQL數據庫做地理位置app應用

熱門標簽:智能外呼系統官網 小裙科技電銷機器人怎樣 呼和浩特外呼系統原理是什么 長沙電銷外呼防封卡是什么 河南電話外呼系統招商 外呼線路資源屬于電信業務嗎 crm外呼系統聯系方式 內蒙古營銷智能外呼系統哪個好 青白江400企業電話申請

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

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

一、兩種可用的選擇

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

二、為什么在數據庫服務器端做計算

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

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

作為開始,你應該先建一個數據庫(我想你知道該怎么做),然后使它們能用我們的架構。 執行:

復制代碼 代碼如下:
CREATE EXTENSION cube;

然后執行:
復制代碼 代碼如下:
CREATE EXTENSION earthdistance;

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

四、計算2個坐標之間的距離

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

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

復制代碼 代碼如下:

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

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

五、找到某個半徑范圍內的記錄

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

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

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

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

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

六、提高查詢速度

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

七、數據類型

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

八、就這些!

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

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

復制代碼 代碼如下:
/*
* postgreSQL之earthdistance學習筆記
* author: wusuopubupt
* date: 2013-03-31
*/

/*創建表*/
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;

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

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

/*選擇距離當前用戶的距離*/
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;

/*
 * 以下內容是網上的一篇教程
 * 地址: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.把直線距離轉成大圓距離
--
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)

您可能感興趣的文章:
  • PostgreSQL數據庫事務實現方法分析
  • Python實現連接postgresql數據庫的方法分析
  • C# 操作PostgreSQL 數據庫的示例代碼
  • 在Ubuntu中安裝Postgresql數據庫的步驟詳解
  • 詳解PostgreSql數據庫對象信息及應用

標簽:池州 菏澤 安順 呼倫貝爾 白山 黃石 舟山 楚雄

巨人網絡通訊聲明:本文標題《用PostgreSQL數據庫做地理位置app應用》,本文關鍵詞  用,PostgreSQL,數據庫,做,地理位置,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《用PostgreSQL數據庫做地理位置app應用》相關的同類信息!
  • 本頁收集關于用PostgreSQL數據庫做地理位置app應用的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲成精国产精品女| 蜜桃视频一区二区| 国产欧美日韩中文久久| 欧美少妇bbb| 日韩精品一级中文字幕精品视频免费观看 | 免费在线一区观看| 懂色av一区二区三区免费看| 亚洲欧美日韩久久| 欧美成人猛片aaaaaaa| 粉嫩av一区二区三区粉嫩 | 香蕉成人伊视频在线观看| 91精品久久久久久蜜臀| 91免费国产在线| 国产美女精品一区二区三区| 亚洲最色的网站| 精品va天堂亚洲国产| 亚洲成人免费av| 欧美曰成人黄网| 99re热这里只有精品免费视频| 青青草精品视频| 亚洲乱码一区二区三区在线观看| 欧美成人精品3d动漫h| 欧美精品乱码久久久久久按摩| 色哟哟一区二区在线观看| 国内精品久久久久影院一蜜桃| 亚洲1区2区3区4区| 亚洲午夜影视影院在线观看| 一区二区三区在线视频免费| 亚洲精品你懂的| 曰韩精品一区二区| 亚洲第一福利视频在线| 午夜影视日本亚洲欧洲精品| 在线播放91灌醉迷j高跟美女| av不卡免费电影| 成人爱爱电影网址| 91免费在线视频观看| 欧美日韩国产电影| 日韩视频一区二区三区| 久久亚洲一区二区三区明星换脸| 精品一区二区三区日韩| 久久久不卡影院| 国产精品久久久久久久久图文区 | 日本韩国精品在线| 精品制服美女丁香| 99精品视频中文字幕| 欧美一区二区高清| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 国产iv一区二区三区| 在线观看视频欧美| 美女视频黄频大全不卡视频在线播放 | 美日韩一区二区| av亚洲精华国产精华精| 欧美一区二区三区四区五区| 国产精品久久久久天堂| 日韩一区二区不卡| 免费成人结看片| 欧美经典三级视频一区二区三区| 亚洲男人天堂av| 成人免费视频视频在线观看免费| 欧美三级一区二区| 高清成人免费视频| 韩国成人在线视频| 亚洲一区二区视频在线观看| 精品国产伦一区二区三区观看方式 | 国产精品欧美一区喷水| 欧美一区二区三区在线观看| 色噜噜狠狠成人网p站| 激情国产一区二区| 午夜精品福利视频网站| 亚洲欧美一区二区三区孕妇| 久久一区二区三区四区| 精品处破学生在线二十三| 欧美体内she精视频| 91在线精品一区二区三区| 国产成人亚洲综合a∨猫咪| 国产真实乱对白精彩久久| 男人操女人的视频在线观看欧美 | 欧美亚洲一区三区| 在线日韩一区二区| 欧美吞精做爰啪啪高潮| 欧美色网一区二区| 欧美久久免费观看| 日韩亚洲欧美一区二区三区| 亚洲精品在线观看网站| 2023国产一二三区日本精品2022| 日韩一区二区三免费高清| 宅男在线国产精品| 久久天天做天天爱综合色| 国产精品免费人成网站| 1区2区3区欧美| 爽好多水快深点欧美视频| 日本亚洲天堂网| 国产精品一区专区| 国产女人aaa级久久久级 | 国产精品1区2区| 91在线精品一区二区三区| 日本午夜精品一区二区三区电影| 久久亚洲精品国产精品紫薇| 中文字幕一区三区| 久久久久久久久久久黄色| 国产精品成人网| 日本特黄久久久高潮| 国产成人免费9x9x人网站视频| 国产suv精品一区二区三区| 91精品婷婷国产综合久久性色| 国产午夜亚洲精品午夜鲁丝片| 亚洲综合在线电影| 成人丝袜视频网| 久久久一区二区三区捆绑**| 偷窥少妇高潮呻吟av久久免费| 成人国产在线观看| 久久综合狠狠综合| 日韩精品欧美成人高清一区二区| 国产成人免费9x9x人网站视频| 欧美性欧美巨大黑白大战| 国产精品久久久久aaaa樱花| 国产精品一卡二卡| 久久久五月婷婷| 久久国产精品色婷婷| 欧美成人r级一区二区三区| 午夜欧美电影在线观看| 色综合色狠狠天天综合色| 亚洲欧美另类小说视频| 不卡高清视频专区| 一区二区成人在线视频| 91福利社在线观看| 天天综合色天天| 这里是久久伊人| 国产麻豆一精品一av一免费 | 一本到一区二区三区| 亚洲人亚洲人成电影网站色| 在线精品视频免费观看| 亚洲1区2区3区视频| 欧美成人艳星乳罩| 成人h版在线观看| 午夜一区二区三区视频| 精品国产髙清在线看国产毛片| 国产成人综合网站| 一区二区三区欧美激情| 久久这里只有精品6| 色婷婷精品大视频在线蜜桃视频| 亚洲国产综合在线| 中文字幕av不卡| 欧美性大战久久久久久久蜜臀| 免费成人小视频| 亚洲欧美一区二区三区国产精品| 欧美三级乱人伦电影| 国产999精品久久久久久绿帽| 亚洲福利视频一区| 中日韩免费视频中文字幕| 欧美精品亚洲二区| 99在线视频精品| 久久精品国产精品青草| 亚洲第一电影网| 悠悠色在线精品| 国产日本欧洲亚洲| 亚洲精品一区在线观看| 欧美午夜不卡视频| 国产精品毛片久久久久久| 美女mm1313爽爽久久久蜜臀| 亚洲一区二区综合| 亚洲人成网站色在线观看| 成人动漫精品一区二区| 国产精品美女久久久久高潮| 26uuu亚洲综合色欧美| 2023国产精品视频| 国产视频一区二区在线| 久久久久久免费毛片精品| 欧美www视频| 2024国产精品| 自拍偷在线精品自拍偷无码专区| 亚洲三级在线观看| 亚洲国产美女搞黄色| 奇米四色…亚洲| 国产精品影音先锋| 91免费国产视频网站| 青草av.久久免费一区| 久久影院视频免费| 中文字幕一区视频| 亚洲18色成人| 国产精品1区2区| 欧美色中文字幕| 久久久99久久精品欧美| 最新日韩av在线| 日韩精品色哟哟| 97精品国产97久久久久久久久久久久| 亚洲h在线观看| 国产精品成人一区二区艾草| 香蕉成人啪国产精品视频综合网 | 亚洲精品自拍动漫在线| 亚洲伦理在线精品| 亚洲图片欧美色图| 国产精品香蕉一区二区三区| 一本一道久久a久久精品综合蜜臀| 在线综合视频播放| 亚洲激情五月婷婷| 成人黄色小视频在线观看| 日韩一区二区视频| 偷窥少妇高潮呻吟av久久免费| 国产精品91一区二区|