网易首页 > 网易号 > 正文 申请入驻

(文档)PG第115讲-空间数据库postgis的使用技巧

0
分享至

Objectives

• PostGIS概述

• PostGIS安装  • PostGIS使用技巧与应用场景

PostGIS概述
• PostGIS通过向PostgreSQL添加对空间数据类型、空间索引和空间函数的支持,将PostgreSQL数据库管理系统转换为空间数据库。

• 因为PostGIS是建立在PostgreSQL之上的,所以PostGIS自动继承了重要的"企业级"特性以及开放源代码的标准。

• PostGIS仅仅只是PostgreSQL的一个插件,但是它将PostgreSQL 变成了一个强大的空间数据库!

• Oracle Spatial和SQL Server(2008和之后版本)也是空间数据库。

PostGIS发展历史

• 2001年5月,Refractions Research 发布了第一版PostGIS。PostGIS 0.1 具有空间对象、空间索引和一些空间函数。PostGIS 0.1是一个适合存储和检索的数据库,但不适合分析。

• 随着空间函数数量的增加,相关标准化组织的需求变得明确。开放地理空间联盟(OGC)的“Simple Features for SQL”(SFSQL)规范提供了 函数命名和要求的指导性原则。

• 后续版本中,PostGIS函数的数量有所增加,但其功能仍然有限。许多函数(如ST_Intersects()、ST_Buffer()、ST_Union()) 都很难编写,从头开始写这些函数花费了几年时间。

• “Geometry Engine, Open Source” (GEOS)库为实现SFSQL规范提供了必要的算法。通过结合GEOS, PostGIS在0.8版中提供了对SFSQL的完整支持。

• 随着PostGIS数据容量的增长,用于存储几何图形的描述(元数据)被证明效率相对较低。对于像点和短线这样的存储对象,元数据的描述占据了多达300%的开销。在PostGIS 1.0中,通过缩减元数据头和所需的维度,大大减少了开销。

• PostGIS最新的更新致力于提高对于标准的遵从性,增加了对ISO SQL/MM 标准中制定的基于曲线的几何图形和函数签名的支持。

• PostGIS 1.4大大提高了几何图形测试例程的速度。

PostGIS安装

1、下载地址:https://postgis.net

2、安装所需要的系统软件包: libxml2 libxml2-dev gdal-bin libgdal-dev

3、源代码安装三步骤:

./configure

make

make install

4、安装插件

create extension postgis;

• 安装完插件后产生以下表和视图:



• spatial_ref_sys :存储着合法的空间坐标系统。

• geometry_columns :用于记录那些表格是有几何信息的。

• geography_columns:用于记录那些表格是有地理信息的

PostGIS几何关系函数

• 这类函数描述几何对象的距离、包含、范围、相等等几何关系,常见函数如下:

ST_Distance

ST_Equals

ST_Disjoint

ST_Intersects

ST_Touches

ST_Within

ST_Overlaps

ST_Contains

PostGIS读写函数

• 这类函数主要用于各种数据类型之间的转换,尤其是Geometry数据类型与其他字符型等数据类型之间的转换,常见函数如下:

ST_AsText

ST_GeomFromText

ST_AsGeoJSON

ST_AsHEXEWKB

ST_AsKML

ST_AsLatLonText

PostGIS几何对象创建函数

• 这类函数用于点、线、多变形等几何对象创建,常见函数如下:

ST_GeomFromEWKT

ST_GeomFromEWKB

ST_MakePoint

ST_MakeBox2D

ST_LineFromText

ST_Polygon

PostGIS几何对象编辑函数

• 这类函数提供对几何图像的平移、翻转、旋转、放大等功能,常见函数如下:

ST_AddPoint

ST_Reverse

ST_Rotate

ST_Scale

ST_Snap

ST_Transform

ST_Translate

ST_TransScale

PostGIS空间关系及测量函数

• 这类函数实现几何对象最远、最近、长度、面积等计算,常见函数如下:

ST_3DClosestPoint

ST_3DDistance

ST_3DDWithin

ST_3DDFullyWithin

ST_3DIntersects

ST_3DLongestLine

ST_3DMaxDistance

ST_3DShortestLine

ST_Area

PostGIS使用技巧一

1、创建存储有关城市(cities)的信息,一个是 ID 编号,一个是城市名

db1=# CREATE TABLE cities ( id int4, name varchar(50) );

2、添加一个空间栏用于存储城市的位置。习惯上这个栏目叫做 the_geom 。它记录了数据是什么类型(点、线、面)、有几维(这里是二维)以及空间坐标系统。此处使用 EPSG:4326 坐标系统

db1=# SELECT AddGeometryColumn ('cities', 'the_geom', 4326, 'POINT', 2);

3、查看表结构,增加了一个存储空间的列



4、插入数据,对于空间栏,使用 PostGIS 的 ST_GeomFromText 可以将文本转化为坐标与参考系号的记录

db1=# INSERT INTO cities (id, the_geom, name) VALUES (1,ST_GeomFromText('POINT(-0.1257 51.508)',4326),'London, England');

db1=# INSERT INTO cities (id, the_geom, name) VALUES (2,ST_GeomFromText('POINT(-81.233 42.983)',4326),'London, Ontario');

db1=# INSERT INTO cities (id, the_geom, name) VALUES (3,ST_GeomFromText('POINT(27.91162491 -33.01529)',4326),'East London,SA');

5、简单查询

select * from cities;

上面简单查询出来的坐标是无法阅读的 16 进制格式。要以 WKT 文本显示,使用 ST_AsText() 或 ST_AsEwkt() 函数,也可以使用 ST_X() 和 ST_Y() 显示一个维度的坐标:

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



6、空间查询,PostGIS 为 PostgreSQL 扩展了许多空间操作功能。以上已经涉及了转换空间坐标格式的 ST_GeomFromText 。多数空间操作以 ST(spatial type)开头,在 PostGIS 文档相应章节有罗列。这里回答一个具体的问题:以米为单位并假设地球是完美椭球,上面三个城市相互的距离是多少?

SELECT p1.name,p2.name,ST_DistanceSphere(p1.the_geom,p2.the_geom) FROM cities AS p1, cities AS p2 WHERE p1.id > p2.id;



PostGIS使用技巧二

1、创建POI表, 表示地图上的餐饮店位置

create table tbl_poi (

id int primary key,

info text,

pos geometry

2、生成10万条记录, 经纬度圈定在一个范围内随机生成

insert into tbl_poi select generate_series(1,100000), md5(random()::text),

ST_SetSRID(ST_MakePoint(120+random(), 35+random()),4326);

3、输入一个经纬度, 由近到远排序输出10条记录

select id,info,pos <-> ST_SetSRID(ST_MakePoint(120, 35),4326) as distance

from tbl_poi order by pos <-> ST_SetSRID(ST_MakePoint(120, 35),4326) limit 4;

4、创建索引

create index on tbl_poi using gist (pos);

5、使用索引加速, 输入一个经纬度, 由近到远排序输出10条记录

select id,info,pos <-> ST_SetSRID(ST_MakePoint(120, 35),4326) as distance

from tbl_poi order by pos <-> ST_SetSRID(ST_MakePoint(120, 35),4326) limit 5;

6、通过索引访问的执行计划

explain select id,info,pos <-> ST_SetSRID(ST_MakePoint(120, 35),4326) as distance

from tbl_poi order by pos <-> ST_SetSRID(ST_MakePoint(120, 35),4326) limit 5;

QUERY PLAN

Limit (cost=0.28..13.25 rows=5 width=45)

-> Index Scan using tbl_poi_pos_idx on tbl_poi (cost=0.28..259358.28 rows=100000 width=45)

Order By: (pos <-> '0101000020E61000000000000000005E400000000000804140'::geometry)

PostGIS制图

以 PostGIS 数据制图需要相应的客户端支持。包括 Quantum GIS、gvSIG、uDig 在内的多种客户端均可以。



PostGIS应用场景

• 地理数据包括观测数据、分析测定数据、遥感数据和统计调查数据。地理数据库已广泛的应用于单车、导航,旅游、水利,农业、安平城市等应用场景,渗透到人民生活点点滴滴中。



特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
小伙骑车撞特斯拉后赔偿1.5万修车费,4S店发票咋只开了9000元?多方回应

小伙骑车撞特斯拉后赔偿1.5万修车费,4S店发票咋只开了9000元?多方回应

大风新闻
2026-01-22 12:09:03
最低-14℃!江苏下一轮降雪又在路上了

最低-14℃!江苏下一轮降雪又在路上了

鲁中晨报
2026-01-22 08:59:40
嘲笑川普的人该补历史课:美国购买格陵兰是150年的国家战略

嘲笑川普的人该补历史课:美国购买格陵兰是150年的国家战略

斌闻天下
2026-01-22 06:20:03
永远不可能被抹杀的历史:四野部队里的那三万日籍士兵

永远不可能被抹杀的历史:四野部队里的那三万日籍士兵

深度报
2026-01-21 21:25:16
湖北省农业事业中心副主任姜卫东接受审查调查

湖北省农业事业中心副主任姜卫东接受审查调查

界面新闻
2026-01-22 17:14:47
车市内卷严重怎么办?遇事不决,学丰田!

车市内卷严重怎么办?遇事不决,学丰田!

电动邦
2026-01-22 14:32:58
当江青还不叫江青时,她是这样的

当江青还不叫江青时,她是这样的

深度报
2026-01-21 22:36:36
欧洲资金开始大规模撤离

欧洲资金开始大规模撤离

贩财局
2026-01-21 22:18:11
炸裂!中粮集团春招公告,学历从大专起步,外语水平居然不设限…

炸裂!中粮集团春招公告,学历从大专起步,外语水平居然不设限…

火山诗话
2026-01-22 10:40:46
欧洲打死也不会想到,这场战争彻底打掉了欧洲五十年的国运

欧洲打死也不会想到,这场战争彻底打掉了欧洲五十年的国运

揭秘历史的真相
2026-01-19 21:05:12
暴雷!广东知名董事长跳楼,公司停业破产清算,近百家门店全关闭

暴雷!广东知名董事长跳楼,公司停业破产清算,近百家门店全关闭

南宗历史
2026-01-22 14:32:06
人民日报,救西贝一命!

人民日报,救西贝一命!

钧言堂
2026-01-22 09:38:41
台军女飞行员郭文静:只要长官敢下令,我会毫不犹豫的击落歼20!

台军女飞行员郭文静:只要长官敢下令,我会毫不犹豫的击落歼20!

顾史
2026-01-21 21:04:39
叶某斌供述:一天骗五六个人应该差不多

叶某斌供述:一天骗五六个人应该差不多

大风新闻
2026-01-22 14:34:05
性萧条是怎么造成的?以前穿小吊带的女性大把,MV全是比基尼小姐姐

性萧条是怎么造成的?以前穿小吊带的女性大把,MV全是比基尼小姐姐

六子吃凉粉
2026-01-22 09:12:09
突发!知名网红“一栗小莎子”确诊癌症,疑熬夜导致,儿子才两岁

突发!知名网红“一栗小莎子”确诊癌症,疑熬夜导致,儿子才两岁

裕丰娱间说
2026-01-22 08:56:07
马克龙犯了什么病?

马克龙犯了什么病?

新民周刊
2026-01-22 09:08:59
美媒昭告全球: 中国不偿还100年前的债务,美国将不承认欠中国的

美媒昭告全球: 中国不偿还100年前的债务,美国将不承认欠中国的

墨印斋
2026-01-22 06:05:46
900万粉丝网红到株洲一村庄办杀猪宴,称村民收场地费还分肉,村干部:他们未报备且破坏村里声誉,已报警

900万粉丝网红到株洲一村庄办杀猪宴,称村民收场地费还分肉,村干部:他们未报备且破坏村里声誉,已报警

极目新闻
2026-01-22 13:53:44
首进澳网32强!王欣瑜2-1爆冷险胜前法网冠军 将战13号种子

首进澳网32强!王欣瑜2-1爆冷险胜前法网冠军 将战13号种子

醉卧浮生
2026-01-22 13:21:34
2026-01-22 17:28:49
CUUG
CUUG
北京神脑资讯技术有限公司
689文章数 18关注度
往期回顾 全部

科技要闻

几千亿只是开胃菜,AI基建还得再砸几万亿

头条要闻

浙江有人领走88888888马年纪念钞 银行员工:随机分配

头条要闻

浙江有人领走88888888马年纪念钞 银行员工:随机分配

体育要闻

跑个步而已,他们在燃什么?

娱乐要闻

钟丽缇土耳其高空落泪 与张伦硕拥吻

财经要闻

申通快递创始人被前夫索要股份

汽车要闻

配备多块娱乐屏 极氪8X内饰曝光

态度原创

游戏
房产
健康
教育
军事航空

科幻生存新爆款!《星际裂变》两周销量超50万

房产要闻

超千亩!三亚基建大幕开启!崖州湾科技城向北猛扩!

打工人年终总结!健康通关=赢麻了

教育要闻

求最大值,中考必考

军事要闻

普京:愿意向"和平委员会"提供10亿美元

无障碍浏览 进入关怀版