PostGIS310升级334

news2025/1/11 2:39:18

环境:

centos7 + postgis3.1.0alpha1 + postgis3.3.4

如果您运行的是 PostGIS 3 或更高版本,则应升级到已安装的具有PostGIS_Extensions_Upgrade功能的最新版本。

SELECT postgis_extensions_upgrade();

 之前测试过从320升级334,直接执行路径升级即可。

但是从310到334不能平滑升级,看了邮件列表解决方案

邮件列表

数据库postgis库更新到334

注意左边是可安装版本,就是数据库lib/postgis-.so版本,如果不是334,请重新安装postgis

还有办法可以验证是否是最新的postgis,在initdb创建一个库,如果依旧是310dev,说明postgis没有更新成功。

建议先备份下postgis库的so,然后删除掉,再拷贝进去。 

尝试平滑升级

postgres=# ALTER EXTENSION postgis UPDATE TO '3.3.4';
2023-10-11 17:27:37.351 CST [32242] ERROR:  extension "postgis" has no update path from version "3.1.0alpha1" to version "3.3.4"
2023-10-11 17:27:37.351 CST [32242] STATEMENT:  ALTER EXTENSION postgis UPDATE TO '3.3.4';
ERROR:  extension "postgis" has no update path from version "3.1.0alpha1" to version "3.3.4"

extension "postgis" has no update path from version "3.1.0alpha1" to version "3.3.4" 

提示没有更新路径。

a)使用内置扩展升级

postgres=# SELECT postgis_extensions_upgrade();
NOTICE:  Extension postgis_raster is not available or not packagable for some reason
NOTICE:  Extension postgis_sfcgal is not available or not packagable for some reason
NOTICE:  Extension postgis_topology is not available or not packagable for some reason
NOTICE:  Extension postgis_tiger_geocoder is not available or not packagable for some reason

因为我只扩展了postgis,所以提示其他扩展不可打包,那么我们都给他扩展了。

create extension postgis_raster ;
CREATE EXTENSION
create extension postgis_topology ;
CREATE EXTENSION
postgres=# create extension fuzzystrmatch ;
CREATE EXTENSION
postgres=# create extension postgis_tiger_geocoder;
CREATE EXTENSION

b)修改310dev版本号(关键步骤)

因为社区说带阿尔法或者贝塔影响升级。

postgres=# UPDATE pg_catalog.pg_extension SET extversion = '3.1.0' WHERE extname IN('postgis', 'postgis_raster','postgis_sfcgal', 'postgis_topology', 'postgis_tiger_geocoder');
UPDATE 5

c)再次使用upgrade升级

SELECT postgis_extensions_upgrade();

postgres=# SELECT postgis_extensions_upgrade();
NOTICE:  Updating extension postgis from 3.1.0 to 3.3.4
NOTICE:  Updating extension postgis_raster from 3.1.0 to 3.3.4
NOTICE:  Updating extension postgis_sfcgal from 3.1.0 to 3.3.4
NOTICE:  Updating extension postgis_topology from 3.1.0 to 3.3.4
NOTICE:  Updating extension postgis_tiger_geocoder from 3.1.0 to 3.3.4
                    postgis_extensions_upgrade
-------------------------------------------------------------------
 Upgrade completed, run SELECT postgis_full_version(); for details
(1 row)

d)检查版本 

postgres=# select * from pg_available_extensions;
             name             | default_version | installed_version |                                                       comment

------------------------------+-----------------+-------------------+-------------------------------------------------------------------------------
--------------------------------------
 plpgsql                      | 1.0             | 1.0               | PL/pgSQL procedural language
 postgis                      | 3.3.4           | 3.3.4             | PostGIS geometry and geography spatial types and functions
 postgis_tiger_geocoder       | 3.3.4           | 3.3.4             | PostGIS tiger geocoder and reverse geocoder
 postgis_raster               | 3.3.4           | 3.3.4             | PostGIS raster types and functions
 postgis_topology             | 3.3.4           | 3.3.4             | PostGIS topology spatial types and functions
 postgis_sfcgal               | 3.3.4           | 3.3.4             | PostGIS SFCGAL functions
 address_standardizer         | 3.3.4           |                   | Used to parse an address into constituent elements. Generally used to support
geocoding address normalization step.
 address_standardizer_data_us | 3.3.4           |                   | Address Standardizer US dataset example
 fuzzystrmatch                | 1.1             | 1.1               | determine similarities and distance between strings
(9 rows)
postgres=# select postgis_full_version();
                                                                                                                               postgis_full_version

----------------------------------------------------------------------------------------------------------------------------------------------------
-------------------------------------------------------------------------------------------------------------------------------
 POSTGIS="3.3.4 0" [EXTENSION] PGSQL="120" GEOS="3.12.0-CAPI-1.18.0" SFCGAL="SFCGAL 1.4.1, CGAL 5.4.5, BOOST 1.72.0" PROJ="8.2.1" GDAL="GDAL 3.6.2,
released 2023/01/02 (debug build)" LIBXML="2.9.11" LIBJSON="0.15" LIBPROTOBUF="1.4.1" WAGYU="0.5.0 (Internal)" TOPOLOGY RASTER
(1 row)

e)检查历史表和新表 

历史表

postgres=# select * from ne_110m_ocean limit 1;
 ogc_fid |




                                                                                                               wkb_geometry





                                                                            | scalerank | featurecla | min_zoom
---------+------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------------------------------------------------------------------
----------------------------------------------------------------------------+-----------+------------+----------
       1 | \x01030000000100000034000000040000001e8e48400000000022a444400c000000d04a4840000000008ae744400c0000000abf4740000000004c7e454004000000a2cb4
7400400000084d44540040000005057474008000000fe4d46400c00000084d64740080000001cd246400c000000a05248400800000034e7464004000000f88c4840fcffffff213347400
c0000005e04494000000000f84d47400c00000096984940040000003c8647400c00000064054a40fcffffffff6647400400000078854a4004000000326d474004000000469c4a40fcfff
fff091e47400c0000003c854a40000000002aa146400400000070154a40fcffffff49b446400400000090a84940fcffffff7f9f46400c000000a6a3494004000000e84146400c0000002
227494000000000124e46400c000000682b4940080000005e2446400c00000016724940fcfffffffb03464004000000d8ab4940080000000a9145400400000032404a40fcffffff69654
5400400000096584a4008000000d23845400400000020394a40000000007e0345400400000052404a400000000044e444400400000048684a4000000000589144400400000056754a400
00000001eef44400400000060dc4a40fcffffffc70f45400c00000010014b400400000092c644400c000000525e4b4008000000be7944400c000000dced4a4000000000c85044400c000
00028754a40040000003270444004000000d8584a40fcffffff4f04444004000000d0ad4a4004000000d6fc43400c000000f08c4a400000000036a5434004000000c2f04a4004000000d
e7943400400000024de4a4008000000fcf342400c000000faf54a4000000000769942400c000000b8e94a4000000000887b42400c000000ce214a4008000000aa5942400c000000d06b4
94008000000bc6f424004000000ee12494000000000f6af42400400000090994840000000009cca42400400000010714840080000000029434004000000a26d484000000000626843400
c000000969c4840fcffffff4f864340040000009ab248400400000022b3434004000000dec84840fcffffff89164440040000004a32494004000000d620444004000000de0a494000000
0005e4344400c00000038cf48400400000054494440040000001e8e48400000000022a44440 |         0 | Ocean      |      0.0
(1 row)

新表

postgres=# CREATE TABLE line (name varchar, geom geometry);
CREATE TABLE
postgres=# INSERT INTO line VALUES ('road', 'LINESTRING(0 0, 1 1, 2 1, 2 2)');
INSERT 0 1
postgres=# select * from line ;
 name |                                                                        geom

------+---------------------------------------------------------------------------------------------------------------------------------------------
-------
 road | 01020000000400000000000000000000000000000000000000000000000000F03F000000000000F03F0000000000000040000000000000F03F00000000000000400000000000
000040
(1 row)

最后感谢社区Regina Obe提供的帮助。谢谢

参考官方文档:https://postgis.net/docs/manual-dev/zh_Hans/postgis_administration.html

 由我们瀚高公司完成的全部中文翻译工作。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

巧用指标平台DataIndex,五步法轻松实现指标管理

开发部门在做指标加工的全流程中,是否经常出现如下问题: 业务部门看指标数据的时候,看到两个名称相似的指标,不清楚两个指标的差异性,来咨询开发部门指标计算口径,开发部门配合业务部门翻找代码&#xff…

RT-Thread HWTIMER设备(学习)

定时器简介 硬件定时器一般有2种工作模式,定时器模式和计数器模式。不管是工作在哪一种模式,实质都是通过内部计数器模块对脉冲信号进行计数,下面是定时器的一些重要概念。 计数器模式:对外部输入引脚的外部脉冲信号计数。定时器…

c语言:通讯录管理系统(文件版本)

前言:在大多数高校内,都是通过设计一个通讯录管理系统来作为c语言课程设计,通过一个具体的系统设计将我们学习过的结构体和函数等知识糅合起来,可以很好的锻炼学生的编程思维,本文旨在为通讯录管理系统的设计提供思路和…

智能电表线路单回路双回路的区别

随着科技的发展和能源管理的需求,智能电表已经成为电力系统中不可或缺的一部分。智能电表可以通过数据通信网络将用电信息实时传输到电力公司,为电力公司提供更精确、实时的用电数据,同时也可以为用户提供更加智能化的用电服务。 在智能电表…

局域网上IP多播与IP单播关于MAC地址的区别

IP单播进行到局域网上的时候: 网际层使用IP地址进行寻址,各路由器收到IP数据报后,根据其首部中的目的IP地址的网络号部分,基于路由表进行查表转发。 查表转发的结果可指明IP数据报的下一跳路由器的IP地址,但无法指明…

pid-limit参数实验

fork炸弹命令 :(){ :|:& };: 可以看到,如果docker没有限制,会遭到fork炸弹恶意 参考 https://www.cyberciti.biz/faq/understanding-bash-fork-bomb/

146616-66-2,胺反应性染料BDP FL NHS Ester,聚乙二醇单烯丙基醚

产品概览:Amine reactive bright,一种光稳定性佳的绿色荧光染料,以发挥独特的分子发光性能。此乃改进型的FAM(荧光素)荧光染料接班人——BDP FL NHS ester,在488nm通道中绽放色彩。这种胺反应性染料&#x…

信息系统项目管理师第四版学习笔记——项目绩效域

干系人绩效域 干系人绩效域涉及与干系人相关的活动和职能。在项目整个生命周期过程中,有效执行本绩效域可以实现的预期目标主要包含:①与干系人建立高效的工作关系;②干系人认同项目目标;③支持项目的干系人提高了满意度&#xf…

在原有的vue(react)项目中引入electron打包成桌面应用(全网最新!)

基于原有的项目中使用electron打包成桌面应用 首先了解electron是什么? 软件简介 Electron 是一个使用 JavaScript、HTML 和 CSS 构建跨平台的桌面应用程序。它基于 Node.js 和 Chromium,被 Atom 编辑器和许多其他应用程序使用。 Electron 兼容 Mac、Windows 和 Linux,可以…

SpringMVC源码分析(二)启动过程之RequestMappingHandlerMapping分析

a、http请求中的url是如何与对应Handler的即Controller对应method映射的? 在上篇中提到在SpringMVC中,初始化9大内置组件的时候其中有一个组件就是HandlerMapping,在初始化HandlerMapping的时候会加载代码中所有标注了Controller和RequestMap…

视频目标分割数据集分享

MOSE: A New Dataset for Video Object Segmentation in Complex Scenes MOSE 是一个新的视频目标分割数据集,旨在解决复杂环境下的目标跟踪和分割。MOSE 包含 2,149 个视频片段和来自 36 个类别的 5,200 个物体,以及 431,725 个高质量物体分割掩码。MOS…

ubuntu安装依赖包时显示需要先安装其所需要的各种安装包)apt-get源有问题

最近在崭新的ubuntu上安装g以及一些其他的依赖与工具时遇到以下报错情况: 依赖环环相扣,手动无法解决。 总结: 出现需要很多依赖项的情况是因为软件源中没有可用的依赖项或者依赖项版本不正确。 其实在Ubuntu系统中,使用sudo…

Java程序设计实验4 | 面向对象(下)

*本文是博主对Java各种实验的再整理与详解,除了代码部分和解析部分,一些题目还增加了拓展部分(⭐)。拓展部分不是实验报告中原有的内容,而是博主本人自己的补充,以方便大家额外学习、参考。 (没…

AI如何帮助Salesforce从业者找工作?

在当今竞争激烈的就业市场中,找到满意的工作是一项艰巨的任务。成千上万的候选人竞争一个岗位,你需要利用一切优势从求职大军中脱颖而出。 这就是AI的用武之地,特别是像ChatGPT这样的人工智能工具,可以成为你的秘密武器。本篇文章…

2.1、如何在FlinkSQL中读取写出到Kafka

目录 1、环境设置 方式1:在Maven工程中添加pom依赖 方式2:在 sql-client.sh 中添加 jar包依赖 2、读取Kafka 2.1 创建 kafka表 2.2 读取 kafka消息体(Value) 使用 format json 解析json格式的消息 使用 format csv 解析…

力扣第98题 验证二叉搜索树 c++ 与上一篇文章相似

题目 98. 验证二叉搜索树 中等 相关标签 树 深度优先搜索 二叉搜索树 二叉树 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当…

淘宝天猫商品历史价格API接口

获取淘宝商品历史价格接口的步骤如下: 注册淘宝开放平台:首先在淘宝开放平台上注册一个账号,并进行登录。创建应用:在淘宝开放平台上创建一个应用,并获取该应用的App Key和App Secret,用于后续的接口调用。…

Python“梦寻”淘宝天猫店铺所有数据接口,淘宝店铺所有商品数据API接口,淘宝API接口申请指南(含代码示例)

获取淘宝店铺所有商品数据的接口可以通过淘宝开放平台获取。 具体操作步骤如下: 在淘宝开放平台注册成为开发者,并创建一个应用,获取到所需的 App Key 和 App Secret 等信息。使用获取到的 App Key 和 App Secret,进行签名和认证…

Android组件通信——Intent(二十三)

1. 认识Intent 1.1 知识点 (1)了解Intent的主要作用; (2)掌握Activity程序对Intent操作的支持; (3)可以使用Intent完成Activity程序间的跳转,也可以通过Intent接收返…

QT基础 QChart绘制折线

目录 1.简单折线 2.数学折线 3.可滑动折线 1.简单折线 //![1] //! 折现段坐标QLineSeries *series new QLineSeries(); //![1]//![2] //! 添加点series->append(0, 6);series->append(2, 4);series->append(3, 8);series->append(7, 4);series->append(10, 5)…