PGSQL安装PostGIS扩展模块

一、PostGIS简介

1、PostGIS介绍

PostGIS是一个空间数据库,空间数据库像存储和操作数据库中其他任何对象一样去存储和操作空间对象。

空间数据与数据库关联起来的三个要素:数据类型、索引和函数。

  • 空间数据类型:用于指定图形为点(point)、线(line)和面(polygon)
  • 多维度空间索引:被用于进行空间操作的高效处理(注意是多维度哦,而不是只有针对二维空间数据的索引)
  • 空间函数:构建于SQL语言中,用于进行空间属性和空间关系的查询

空间数据类型、空间索引和空间函数组合在一起,提供了灵活的结构用于空间数据库的性能优化和分析。

空间数据库将空间数据和对象关系数据库(Object Relational database)完全集成在一起。实现从以GIS为中心向以数据库为中心的转变。

PostGIS通过向PostgreSQL添加对空间数据类型、空间索引和空间函数的支持,将PostgreSQL数据库管理系统转换为空间数据库。因为PostGIS是建立在PostgreSQL之上的,所以PostGIS自动继承了重要的"企业级"特性以及开放源代码的标准。

参考文章:PostGIS教程一:PostGIS介绍:https://zhuanlan.zhihu.com/p/62034688

2、安装 PostGIS的目的

因为空间数据具有空间位置、空间关系、分类编码、海量数据等特征,所以一般的数据库管理系统无法储存空间数据,如PostgreSQL。

为了达到储存空间数据这个目的,就需要将普通数据库转变为空间数据库。那么具体如何解决这个问题呢?

“关系型数据库+空间数据引擎”通常是近年来由GIS厂商研发的一种中间件解决方案。用户将自己的空间数据交给独立于数据库之外的空间数据引擎,由空间数据引擎来组织空间数据在关系型数据库中的存储。当用户需要访问数据的时候,再通知空间数据引擎,由引擎从关系型数据库中取出数据,并转化为客户可以使用的方式。

而 PostGIS则在其中为空间数据引擎提供支持。它为PostgreSQL提供对空间数据类型、空间索引和空间函数等的空间信息服务,将PostgreSQL转变为可以储存空间数据的数据库。

简单来说,PostGIS仅仅只是PostgreSQL的一个插件,但是它将PostgreSQL变成了一个强大的空间数据库!PostGIS可以看作为空间数据进出该容器的转换通道,而关系型数据 PostgreSQL是存放空间数据的容器。

二、安装PostGIS

我们安装好 PostgreSQL数据库之后。下面为 PostgreSQL安装 PostGIS扩展模块。

1、PostGIS安装

PostGIS下载:http://download.osgeo.org/postgis/windows/

在这里插入图片描述

根据自己安装的 PostgreSQL版本来选择,因为本人安装的 PostgreSQL14,所以下面是对应 PostgreSQL14的window64位的安装包。

(1)双击安装包。

安装时我们勾选Create spatial database。表示创建一个空间数据库(postgis_34_sample),后面你不用时也可以删除它。

在这里插入图片描述

(2)选择安装路径时一定要保证与 PostgreSQL的安装路径保持一致

在这里插入图片描述

(3)需要验证 PostgreSQL的用户名和密码

在这里插入图片描述

在这里插入图片描述

(4)其他就一路next即可,安装成功之后打开pgAdmin查看数据库建立并连接成功。

这里我们就看到创建的 postgis_34_sample空间数据库。

在这里插入图片描述

2、数据库添加扩展

给指定的数据库添加扩展时执行下面语句。

CREATE EXTENSION postgis;

我们创建一个 test_gis数据库,并给它添加 PostGIS扩展,执行上面语句。执行成功之后,public中的表会多一个 spatial_ref_sys表(不要删除)。

在这里插入图片描述

3、验证

执行下面测试语句不报错即可。

SELECT st_asText(st_geomfromtext('POINT(114 50)', 4326));SELECT ST_SetSRID(ST_Point(-87.71,43.741), 4326), ST_GeomFromText('POINT(-87.71 43.741)', 4326);

在这里插入图片描述

三、常用的空间数据函数

PostGIS 提供了丰富的空间数据函数,用于存储、分析和处理空间数据。

以下是一些常用的空间数据函数以及它们的作用:

1、几何对象创建函数:

  • ST_GeomFromText(wkt, srid):从 Well-Known Text (WKT) 格式的文本创建几何对象。可以选择性地指定坐标系标识。
  • ST_GeomFromEWKT(ewkt):从扩展的 Well-Known Text (EWKT) 格式的文本创建几何对象,包括坐标系信息。
  • ST_Point(x, y):创建一个点几何对象。
  • ST_LineString(points):创建一个线几何对象。
  • ST_Polygon(rings):创建一个多边形几何对象。

2、几何对象检查函数:

  • ST_IsValid(geometry):检查几何对象是否有效。
  • ST_IsEmpty(geometry):检查几何对象是否为空。
  • ST_GeometryType(geometry):返回几何对象的类型。

3、几何对象转换函数:

  • ST_AsText(geometry):将几何对象转换为 Well-Known Text (WKT) 格式的文本。
  • ST_AsEWKT(geometry):将几何对象转换为扩展的 Well-Known Text (EWKT) 格式的文本。
  • ST_SetSRID(geometry, srid):设置几何对象的坐标系标识。

4、空间关系函数:

  • ST_Intersects(geom1, geom2):检查两个几何对象是否相交。
  • ST_Contains(geom1, geom2):检查一个几何对象是否包含另一个几何对象。
  • ST_Distance(geom1, geom2):计算两个几何对象之间的距离。

5、空间分析函数:

  • ST_Buffer(geometry, distance):对几何对象进行缓冲区分析。
  • ST_Intersection(geom1, geom2):计算两个几何对象的交集。
  • ST_Union(geom1, geom2):计算两个几何对象的并集。

6、几何对象编辑函数:

  • ST_Transform(geometry, srid):将几何对象转换到指定的坐标系。
  • ST_Simplify(geometry, tolerance):对几何对象进行简化处理。
  • ST_Centroid(geometry):计算几何对象的质心。

7、几何对象测量函数:

  • ST_Area(geometry):计算几何对象的面积。
  • ST_Length(geometry):计算几何对象的长度。
  • ST_Perimeter(geometry):计算几何对象的周长。

8、几何对象索引函数:

  • ST_GeoHash(geometry):计算几何对象的 GeoHash 值。
  • ST_MakeEnvelope(minx, miny, maxx, maxy, srid):创建一个表示矩形范围的几何对象。

9、几何对象集合函数:

  • ST_Collect(geometry1, geometry2):将多个几何对象合并为一个几何对象集合。
  • ST_Extent(geometry):计算几何对象的外接矩形范围。

10、几何对象输出函数:

  • ST_AsGeoJSON(geometry):将几何对象转换为 GeoJSON 格式的文本。
  • ST_AsKML(geometry):将几何对象转换为 KML 格式的文本。

参考文章:

  • Postgis 图文安装详细教程 (Windows):https://blog.csdn.net/LY1201A/article/details/107080664

– 求知若饥,虚心若愚。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/418204.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LLM:Scaling Laws for Neural Language Models (上)

论文:https://arxiv.org/pdf/2001.08361.pdf 发表:2020 摘要1:损失与模型大小、数据集大小以及训练所用计算量成比例,其中一些趋势跨越了七个量级以上。 2:网络宽度或深度等其他架构细节在很大范围内影响较小。3&…

使用STM32的GPIO口实现LED闪烁

✅作者简介:热爱科研的嵌入式开发者,修心和技术同步精进 代码获取、问题探讨及文章转载可私信。 ☁ 愿你的生命中有够多的云翳,来造就一个美丽的黄昏。 🍎获取更多嵌入式资料可点击链接进群领取,谢谢支持!&#x1f447…

ros2 基础教程-使用ROS 2进行相机标定

ROS 2进行相机标定(Camera Calibration) 相机(摄像头)是一种非常精密的光学仪器,对外界环境的感知非常敏感。由于摄像头内部和外部的一些原因,摄像头采集的图像常常会发生一定的畸变。如果直接将采集到的图…

ubuntu20遇到缺少qt4相关库的问题

最近需要做套接字通讯的工作,最好是有一个网络调试软件能够接受或者发送套接字,测试代码能够正常通讯。windows下有很多,但是linux下比较少,使用广泛的是下面这一款。 1、安装 首先从网盘(链接: https://pan.baidu.c…

【51单片机Keil+Proteus8.9】控制步进电机+LCD1602显示状态

步进电机控制 设计思路 电路设计: 选用AT89C51单片机作为电路核心部件,外加LM016L液晶显示屏作为显示,显示步进电机的Fast,Slow,Stop的三个状态将AT89C51单片机所选引脚与LM016L控制引脚相连,再将数据通…

ros2 基础学习16 - RQT:模块化可视化工具

RQT:模块化可视化工具 ROS中的Rviz功能已经很强大了,不过有些场景下,我们可能更需要一些简单的模块化的可视化工具,比如只显示一个摄像头的图像,使用Rviz的话,难免会觉得操作有点麻烦。 此时,我…

C++力扣题目435-无重叠区间 763--划分字母区间

435. 无重叠区间 力扣题目链接(opens new window) 给定一个区间的集合,找到需要移除区间的最小数量,使剩余区间互不重叠。 注意: 可以认为区间的终点总是大于它的起点。 区间 [1,2] 和 [2,3] 的边界相互“接触”,但没有相互重叠。 示例 1…

React16源码: React中的renderRoot的源码实现

renderRoot 1 )概述 renderRoot 是一个非常复杂的方法这个方法里处理很多各种各样的逻辑, 它主要的工作内容是什么?A. 它调用 workLoop 进行循环单元更新 遍历整个 Fiber Tree,把每一个组件或者 dom 节点对应的Fiber 节点拿出来单一的进行更…

探索世界,从一款好用的浏览器开始!

好用的浏览器分享 在这个数字化的时代,浏览器已经成为了我们生活中不可或缺的工具。从浏览新闻、社交媒体到工作学习,我们几乎无时无刻不在与浏览器打交道。那么,如何选择一款好用的浏览器呢?今天,我就来为大家分享几…

实验七 RMAN恢复管理器

🕺作者: 主页 我的专栏C语言从0到1探秘C数据结构从0到1探秘Linux 😘欢迎关注:👍点赞🙌收藏✍️留言 🏇码字不易,你的👍点赞🙌收藏❤️关注对我真的很重要&…

集合框架(三)

Set集合 特点 Set系列集合特点: 无序:添加数据的顺序和获取出的数据顺序不一致;无重复;无索引; HashSet:无序、不重复、无索引LinkedHashSet:有序、不重复、无索引TreeSet:排序、…

git提交代码到远端仓库的方法详解

一、何为git git就是版本控制器,就比如说你新建了一个git文件夹,里面用于存放你的C语言实习报告,现在要用git对该文件夹进行接管。当你修改了你的C语言实习报告点击保存之后,就用git的相关命令,提交给git,让…