PostGIS 筆記一:簡單入門

PostGIS 筆記一:簡單入門

Postgis是基于PostgreSQL的空間擴展木张。所以你懂得PostgreSQL不代表你就懂得Postgis咳蔚,你懂得Postgis也不代表你就懂得PostgreSQL。如果你看過我關于Spatialite的筆記锯茄,你具備了一定空間數據庫的基礎厢塘。

使用

Postgis分為兩個大版本,它們之間有較大幅度的更新肌幽,網上很多教程都是基于舊版本的postgis晚碾。在安裝的階段當中,新版本的postgis會出現“template_postgis模板不存在”的問題喂急。解決方案有兩個:

CREATE EXTENSION postgis

同樣,很多第三方庫也會區(qū)分postgis的版本廊移,專門針對2.0版本后進行定制糕簿。

運用

空間字段可以分為geometry和geography兩種,大部分情況使用滿足opengis標準的geometry狡孔。

創(chuàng)建空間字段

方法一

打開空間擴展后懂诗,前提是你首先創(chuàng)建一張表,運用opengis標準推薦的方法創(chuàng)建空間字段苗膝。

SELECT AddGeometryColumn ('scheme'殃恒,'cities', 'the_geom', 4326, 'POINT', 2);

缺點在于這是一個擴展的方法,表名荚醒、字段名等參數是區(qū)分大小寫的芋类。

方法二

也可以使用geometry type的方法隆嗅,同時創(chuàng)建表界阁。

CREATE TABLE ROADS ( ID int4, ROAD_NAME varchar(25), geom geometry(LINESTRING,4326) );

或者修改表

ALTER TABLE roads ADD COLUMN geom2 geometry(LINESTRINGZ,4326);

插入一條數據

由于空間數據的描述相對復雜,空間數據的插入需要依靠別的數據格式進行轉換胖喳。ST_GeomFromText是從文本進行轉換泡躯。

INSERT INTO roads (road_id, roads_geom, road_name) VALUES (3,ST_GeomFromText('LINESTRING(192783 228138,192612 229814)',-1),'Paul St');

或者用wkt,可以參考WKT&WKB 筆記一:格式介紹丽焊。

INSERT INTO table ( SHAPE, NAME )VALUES ( GeomFromEWKT('SRID=4326;POINTM(116.39 39.9 10)'), '北京' )

讀取一條數據

顯示數據可以將空間字段保存成不同的格式较剃。

 SELECT id, ST_AsText(the_geom), ST_AsGeoJson(the_geom), ST_AsEwkt(the_geom), ST_X(the_geom), ST_Y(the_geom) FROM cities;

用Geography數據格式不用Geometry數據格式

新型的GEOGRAPHY格式允許你用longitude/latitude coordinates存數據,但是有一個代價:針對GEOGRAPHY很少方法被定義技健,而針對GEOMETRY相對較多写穴。而且這些方法都相對來說更消耗CPU。

你選擇這個數據類型必須是因為你應用的情況雌贱。你的數據如果是全球或者大陸范圍或者是一個洲啊送,一個國家或者一個城市偿短。

  • 如果數據在一個很小的范圍內,你可能需要選擇一個恰當的投影馋没,用Geometry是最好的解決方案昔逗,因為性能優(yōu)先和功能可用。
  • 你的數據是全球或者大范圍的篷朵,你會發(fā)現GEOGRAPHY讓你建立一個系統(tǒng)不用擔心投影信息勾怒。你可以用經緯度存起你的數據。
  • 你不懂得投影声旺,你也不想去學投影笔链,你可以接受GEOGRAPHY的方法缺失,你應該選擇GEOGRAPHY而不是GEOMETRY艾少。因為這樣更方便你去加載用經緯度數據卡乾。

來自PostGIS_Geography VS Geometry

空間分析方法

PostGIS_GeographyFunctions

參考

PostgreSQL的postgres_fdw跨庫使用

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市缚够,隨后出現的幾起案子幔妨,更是在濱河造成了極大的恐慌,老刑警劉巖谍椅,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件误堡,死亡現場離奇詭異,居然都是意外死亡雏吭,警方通過查閱死者的電腦和手機锁施,發(fā)現死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來杖们,“玉大人悉抵,你說我怎么就攤上這事≌辏” “怎么了姥饰?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長孝治。 經常有香客問我列粪,道長,這世上最難降的妖魔是什么谈飒? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任岂座,我火速辦了婚禮,結果婚禮上杭措,老公的妹妹穿的比我還像新娘费什。我一直安慰自己,他們只是感情好手素,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布鸳址。 她就那樣靜靜地躺著赘那,像睡著了一般。 火紅的嫁衣襯著肌膚如雪氯质。 梳的紋絲不亂的頭發(fā)上募舟,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天,我揣著相機與錄音闻察,去河邊找鬼拱礁。 笑死,一個胖子當著我的面吹牛辕漂,可吹牛的內容都是我干的呢灶。 我是一名探鬼主播,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼钉嘹,長吁一口氣:“原來是場噩夢啊……” “哼鸯乃!你這毒婦竟也來了?” 一聲冷哼從身側響起跋涣,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤缨睡,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后陈辱,有當地人在樹林里發(fā)現了一具尸體奖年,經...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年沛贪,在試婚紗的時候發(fā)現自己被綠了陋守。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡利赋,死狀恐怖水评,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情媚送,我是刑警寧澤中燥,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站季希,受9級特大地震影響褪那,放射性物質發(fā)生泄漏幽纷。R本人自食惡果不足惜式塌,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望友浸。 院中可真熱鬧峰尝,春花似錦、人聲如沸收恢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至火窒,卻和暖如春硼补,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背熏矿。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工已骇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人票编。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓褪储,卻偏偏與公主長得像,于是被迫代替她去往敵國和親慧域。 傳聞我的和親對象是個殘疾皇子鲤竹,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內容