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

(文档)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.

相关推荐
热点推荐
蒋方舟红了20年的真相:常年身处争议的中心,窦文涛是最大底牌?

蒋方舟红了20年的真相:常年身处争议的中心,窦文涛是最大底牌?

智慧生活笔记
2026-07-05 06:01:46
林徽因落选的国徽方案,网友看后感叹:审美确实一绝,但真不合适

林徽因落选的国徽方案,网友看后感叹:审美确实一绝,但真不合适

兴趣知识
2026-07-04 01:34:41
U17中国男篮14分逆转新西兰!中途换教练收获奇效,给郭士强打样

U17中国男篮14分逆转新西兰!中途换教练收获奇效,给郭士强打样

多特体育说
2026-07-05 10:41:14
武汉会战就决定了日本赢不了,真正的关键不是日军死伤25万多个兵

武汉会战就决定了日本赢不了,真正的关键不是日军死伤25万多个兵

磊子讲史
2026-07-03 17:38:58
甲钴胺能长期吃吗?吃吃停停可以吗?本文一次性告诉您答案

甲钴胺能长期吃吗?吃吃停停可以吗?本文一次性告诉您答案

药师方健
2026-06-12 22:46:03
没有证据?那就发明证据!从中国第一“女福尔摩斯”到冤案制造者

没有证据?那就发明证据!从中国第一“女福尔摩斯”到冤案制造者

许三岁
2026-06-24 11:06:59
梅德韦杰夫早已看透,无论俄乌战事谁输谁赢,都将是他的上位良机

梅德韦杰夫早已看透,无论俄乌战事谁输谁赢,都将是他的上位良机

喊山的姑娘
2026-07-05 12:58:53
钱再多有啥用!“展昭”何家劲的现状,给所有老年男性提了个醒

钱再多有啥用!“展昭”何家劲的现状,给所有老年男性提了个醒

元宝课堂
2026-06-22 20:49:31
19股获机构大手笔净买入

19股获机构大手笔净买入

证券时报e公司
2026-07-05 07:52:17
暴雨、10级大风!杭州人千万别大意,今天还有!超强台风“巴威”也要来了......

暴雨、10级大风!杭州人千万别大意,今天还有!超强台风“巴威”也要来了......

鲁中晨报
2026-07-05 15:34:05
7月5日美国大满贯战报 松岛辉空4-0林德 王楚钦出局最大受益者

7月5日美国大满贯战报 松岛辉空4-0林德 王楚钦出局最大受益者

南海浪花
2026-07-05 06:39:23
60岁大妈哭诉:拒绝同房后,老伴竟跟我闹离婚,我错了吗?

60岁大妈哭诉:拒绝同房后,老伴竟跟我闹离婚,我错了吗?

烙任情感
2026-07-04 11:38:15
小猎豹下跪求资源!张凌赫在饭局中尿遁!

小猎豹下跪求资源!张凌赫在饭局中尿遁!

八卦疯叔
2026-07-05 11:37:10
天山铝业:预计2026年上半年归属于上市公司股东的净利润42亿元

天山铝业:预计2026年上半年归属于上市公司股东的净利润42亿元

每日经济新闻
2026-07-05 15:40:37
收手吧!“资本家的丑孩子”,没实力没长相,放过观众吧

收手吧!“资本家的丑孩子”,没实力没长相,放过观众吧

笑一个吧
2026-07-05 13:18:38
世纪婚礼落地!泰勒·斯威夫特官宣大婚,捐1.7亿超婚礼开销

世纪婚礼落地!泰勒·斯威夫特官宣大婚,捐1.7亿超婚礼开销

雅儿姐游世界
2026-07-04 14:47:40
高市下令涨5倍签证费,转头中国新规落地,日本财政爆雷如何自救

高市下令涨5倍签证费,转头中国新规落地,日本财政爆雷如何自救

史智文道
2026-07-05 09:55:39
恒大高管刘永灼,他的行为比许家印还“败家”

恒大高管刘永灼,他的行为比许家印还“败家”

风流女汉
2026-07-05 04:10:56
两个改动温暖工体,北京国安用心调整让现场观赛体验大幅升级

两个改动温暖工体,北京国安用心调整让现场观赛体验大幅升级

兰亭墨未干
2026-07-05 15:55:42
意大利门将布冯,超模老婆身材火辣,红杏出墙,曾与多名球星有染

意大利门将布冯,超模老婆身材火辣,红杏出墙,曾与多名球星有染

乡野小珥
2026-07-05 15:50:21
2026-07-05 16:35:00
CUUG
CUUG
北京神脑资讯技术有限公司
720文章数 18关注度
往期回顾 全部

科技要闻

华为:逻辑折叠将大幅提升麒麟CPU核心频率

头条要闻

特朗普:我很惊讶 悼念哈梅内伊的伊朗民众"全是假哭"

头条要闻

特朗普:我很惊讶 悼念哈梅内伊的伊朗民众"全是假哭"

体育要闻

姆巴佩点走巴拉圭:巴黎三代左锋传承

娱乐要闻

王力宏成都舞台受伤 仍然坚持三小时

财经要闻

揭秘跨境“对敲”换汇黑产

汽车要闻

方程豹钛9内饰曝光 用上了长联屏设计/下半年上市

态度原创

房产
教育
亲子
时尚
军事航空

房产要闻

总裁空缺17个月、现金缺口超1000亿:金融局“局外人”入局万科

教育要闻

暑假想废掉一个孩子,就让他长期宅在恒温26度的家里

亲子要闻

在@我是机灵姐家里,我看到有爱的家庭养出了孩子最好的模样。

为什么女明星体重涨了,身材反而更辣了?

军事要闻

普京与特朗普通话85分钟 细节公布

无障碍浏览 进入关怀版