- VisualStudio2022插件的安装及使用-编程手把手系列文章
- pprof-在现网场景怎么用
- C#实现的下拉多选框,下拉多选树,多级节点
- 【学习笔记】基础数据结构:猫树
PostGIS 是一个开源数据库拓展,它为 PostgreSQL 数据库增加了对地理空间数据的支持。PostGIS 使得空间数据的存储、查询和分析变得简单高效.
PostGIS 是 Postgresql 的一个插件,本文将介绍 Unbuntu 平台下如何安装 PostGIS 拓展的一些步骤和注意的问题.
在安装 PostGIS 前应该先安装好 Postgresql.
版本说明: Unbuntu Version:22.04.4 Postgresql Version:14 。
安装 PostGIS 前读者可以先确认下正在使用的 Postgresql 版本,根据 Postgresql 的版本来确定你要安装哪个版本的 PostGIS.
# 查看 postgresql 版本
# 切换到 postgres 用户
su postgres
# 进入 postgresql 数据库
psql
# 查看 postgresql 数据库版本
SELECT version();
PostgreSQL 与 PostGIS 对应支持关系 。
PostgreSQL Version | PostGIS Version |
---|---|
11(EOL) | 2.5(EOL)、3.0、3.1、3.2、3.3 |
12 | 2.5(EOL)、3.0、3.1、3.2、3.3、3.4、3.5 |
13 | 3.0、3.1、3.2、3.3、3.4、3.5 |
14 | 3.1、3.2、3.3、3.4、3.5 |
15 | 3.2、3.3、3.4、3.5 |
16 | 3.3、3.4、3.5 |
17 | 3.3、3.4、3.5 |
统计时间为:2024-09-04 ,其中标注为(EOL)的是官方不再支持更新的。所以最好选择较新版本的。这个列表官方可能会有变动,最新信息见参考目录的“PostGIS 版本对应关系”.
我在安装的时候,本地的 postgresql 的版本是 14 ,所以我这里选择安装 PostGIS 3.3.
PostGIS 还需要依赖一些库,比如:GEOS、Proj、protobuf-c 、GDAL等,他们之间也有一些版本的依赖和匹配关系,具体关系见参考目录的“PostGIS 版本对应关系”.
除了上面三个特意标出来的依赖库,还需要依赖一些如xml2、libpq等库,但是暂时先不用管,到安装的时候会提示你缺少哪些东西,到时候再安装也不晚.
如果读者使用源码编译安装,那么 gcc、g++、make、cmake 等这些工具都需要提前装好,或者等遇到报错后再取百度就行了,这里就不浪费篇幅了.
Geos下载地址 。
这里我选择的版本是 Geos3.12.2,下载的文件为 geos-3.12.2.tar.bz2.
源码安装:
# 解压
sudo tar jxf geos-3.12.2.tar.bz2
# 进入解压出来的目录的src目录
cd geos-3.12.2/src
# 构建
sudo cmake ../
# 编译
sudo make
# 安装
sudo make install
sudo 命令大家应该都知道,这里就不说了,如果用的是虚拟机的 root 用户安装的可以不加 sudo.
也可以直接apt安装:sudo apt-get install libgeos-dev 。
Proj 9 下载地址 。
这里我选择的是 Proj 9.4.1,下载的文件为 proj-9.4.1.tar.gz.
源码安装:
# proj 9 需要依赖sqlite3和TIEF和CURL的一些库,如果之前没安装可以执行下面命令安装
sudo apt-get install libsqlite3-dev
sudo apt-get install libtiff-dev
sudo apt-get install libcurl4-openssl-dev
# 将下载的proj包解压
sudo tar zxf proj-9.4.1.tar.gz
# 进入目录
cd proj-9.4.1/
# 建个build目录
sudo mkdir build
# 进入build目录
cd build
# 构建编译和安装
sudo cmake ..
sudo cmake --build .
sudo cmake --build . --target install
也可以直接apt安装:sudo apt-get install libproj-dev 。
protobuf-c下载地址 protobuf-c源码地址 。
这里我选择的是 1.5.0,下载的文件为 protobuf-c-1.5.0.tar.gz.
源码安装:
# 解压
sudo tar zxf protobuf-c-1.5.0.tar.gz
# 配置
sudo ./configure
# 编译
sudo make
# 安装
sudo make install
安装 protobuf-c 的时候需要依赖一些其他的库,比如:protobuf,pkg-config等,也要先安装。具体可以看 protobuf-c 的 github仓库,这里就不多说了.
也可以直接apt安装:sudo apt-get install libprotobuf-c-dev 。
Gdal 官网地址 Gdal 仓库地址 。
这里我选择的是 gdal-3.5.3.tar.gz.
源码安装:
# 解压
sudo tar xf gdal-3.5.3.tar.gz
# 进入解压出的目录
cd gdal-3.5.3/
# 配置
./configure --prefix=/usr/local/gdal
# 编译
sudo make
# 安装
sudo make install
也可以直接apt安装:sudo apt-get install libgdal-dev 。
上面的准备工作做好了,我们就可以安装 Postgis 了。当然你要是不确定哪些库你已经安装了,也可以先直接安装 Postgis 。在执行 ./configure 的时候,如果缺少某些依赖库,它会提醒你,然后再去安装就可以了.
PostGIS 官网 。
我这里使用的是 postgis-3.3.6.tar.gz 版本.
源码安装:
# 解压
sudo tar zxf
# 进入目录
# 配置
# --with-pgsql 要改成读者自己的 postgresql 目录下的 pg_config 文件路径。
# --with-gdalconfig 就是上面刚安装的 gdal 路径下的 gdal-config 文件路径。
sudo ./configure --with-pgsql=/usr/lib/postgresql/14/bin/pg_config --with-gdalconfig=/usr/local/gdal/bin/gdal-config
# 编译
sudo make
# 安装
sudo make install
如果在 执行 make 的时候报 fatal error: postgres.h No such file or directory 的错误,可以安装一下 sudo apt install postgresql-server-dev-XX (xx换成你的postgresql版本).
也可以直接apt安装:sudo apt-get install postgis 。
安装成功后可以进入 postgresql 数据库,在数据库中创建 postgis 拓展插件.
# 切换到 postgres 用户
su postgres
# 链接进入数据库
postgres@virtual-machine:/$ psql
psql (14.13 (Ubuntu 14.13-0ubuntu0.22.04.1))
Type "help" for help.
postgres=#
#创建 postgis 拓展
postgres=# create extension postgis;
CREATE EXTENSION
# 查看一下是否创建成功
postgres=# select * from pg_available_extensions where name like 'postgis%';
name | default_version | installed_version | comment
------------------------+-----------------+-------------------+------------------------------------------------------------
postgis_raster | 3.3.6 | | PostGIS raster types and functions
postgis_tiger_geocoder | 3.3.6 | | PostGIS tiger geocoder and reverse geocoder
postgis_topology | 3.3.6 | | PostGIS topology spatial types and functions
postgis | 3.3.6 | 3.3.6 | PostGIS geometry and geography spatial types and functions
(4 rows)
# 创建插件拓展
create extension postgis;
# 创建表格
CREATE TABLE t_point(
"id" int4 NOT NULL,
"point" geometry(point, 4326),
PRIMARY KEY ("id")
);
# 插入数据
INSERT INTO t_point
(id,point)
VALUES
(1,ST_GeomFromText('Point(31.2323 120.2323)',4326))
# 查询数据
SELECT id,ST_ASTEXT(point) FROM t_point WHERE id = 1
ST_ASTEXT、ST_GeomFromText是内置方法,其他一些常用方法可以参考:官方文档 。
完... 。
最后此篇关于Postgresql——postgis安装的文章就讲到这里了,如果你想了解更多关于Postgresql——postgis安装的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我听说最好不要从您系统的 Perl 版本所在的 CPAN 安装模块。我知道如何使用命令行安装模块,我只是想知道是否有办法将 CPAN 与系统核心 Perl 分开。 我应该: 下载源代码并专门为这些模块
我听说最好不要从系统的 Perl 版本所在的 CPAN 安装模块。我知道如何使用命令行安装模块,我只是想知道是否有办法将 CPAN 与系统的核心 Perl 分开。 我应该: 下载源代码并专门为这些模块
单独安装 electron 与通过 electron-builder 安装有什么区别?我正在使用 React 构建一个 Electron 应用程序,并且已经找到了一些教程。它们安装 Electron
两者安装有什么区别?我按照安装页面上的说明在全局范围内安装了 webpack,然后我转到了入门指南,据说在那里可以在本地安装 webpack-cli。 CLI = Command Line Inter
我在 OS X Yosemite 上用 PHP 安装了默认的 Apache 服务器,安装了 pear,用 brew 安装了 Solr (brew install solr),现在我正在尝试使用 PEC
我解压并编译了 Ruby 2.1 并安装了几个支持工具。 但是当我安装了 libssl-dev 时,OpenSSL 不会安装。 我在支持 openssl 时遇到这个错误: make: *** No r
我在 android studio 2.3.1 和 gradle 3.2 中设计了 2 到 3 个应用程序。当我从它运行应用程序到任何设备或模拟器时,一切都工作正常。但是当我从构建文件夹中获取该 ap
我注意到我正在读一本书提到通过 apt-get 安装 numpy 和 opencv apt-get install python-numpy python-opencv 但我可以通过以下方式在 pip
我正在尝试在 Windows 8.1 上安装 ansicon。我提取了文件并达到了我需要调用 ansicon -i 的级别。当我在 cmd 中输入此内容并运行 python 脚本时效果很好,但是当我通
我有 linux MINT 17.3 Kernel 4.4.0-81 所有更新可用。 (由于不同的原因,我无法迁移到更新版本的 ubuntu/mint) 我已经通过 PPA 安装了 FFMPEG(不是
尝试在本地运行我的应用程序时出现错误: 我只在 chrome 浏览器中收到此错误。我尝试过不同的东西,但我不确定为什么它是 Chrome 特定的。 最佳答案 我怀疑这不是 Firebase 问题,而是
这是我第一次开发 AngularJS 应用程序并使用脚手架工具 Yeoman ( http://yeoman.io/ )。我想对我的一些图标使用 fontawesome ( http://fortaw
我知道您通常“应该”$ pip install 如果包没有 brew ,但如果有一个你想安装的 python 包,你可以使用 $ pip install或 $ brew install为了?例如,通过
我正在尝试通过 RVM 安装 Ruby 1.9.3。然而,当谈到安装 RubyGems 时,我得到了这个: curl: (22) The requested URL returned error: 4
我是真正提出问题的新手,但你去吧。 我一直在尝试按照安装指南添加 dnsname: https://github.com/containers/dnsname https://github.com/c
Studio更新至0.4.0 建筑产量为“需要1.8版Gradle”;将设置设置为1.8 bin目录; 建立 “要求1.9级”;将设置设置为1.9 bin; 建立 “要求1.8级” 啊。不知道该怎么做
我刚刚注意到 kernel.org 因维护而停机。是否有使用不同镜子的不同公式?或者我可以向 Homebrew 软件添加不同的来源(如 bundler ?)? 谢谢你的帮助! 最佳答案 快速解决方法:
当我运行时: peardev install phpunit/PHPUnit 我得到以下信息: No releases available for package "pear.phpunit.de/P
服务器操作系统为Fedora 24. 64bit。 我想安装 Git 2.6.6。 所以下载源码并安装。 此服务器离线。所以我不使用“yum”。 ./configure --prefix=/usr/l
我正在尝试在我自己的服务器(操作系统:Linux Ubuntu Server 12.04)上安装 OpenEdX,但我遇到了同样的错误。谁能帮帮我? TASK: [ insights | insta
我是一名优秀的程序员,十分优秀!