首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何重写引用postgis库的postgres函数?

如何重写引用postgis库的postgres函数?
EN

Stack Overflow用户
提问于 2020-07-07 15:16:47
回答 1查看 114关注 0票数 2

我最近将postgres版本从9.4升级到10.1。同时,我希望将postgis从2.1版升级到3版。

我所做的就是转储我的数据库并在我的新postgres上恢复它。但这是我面临的问题。由于许多函数使用AS '$libdir/postgis-2.1'引用postgis库,因此我看到一个错误:它找不到$libdir/postgis-2.1。

当然,它不能,因为我的新postgres的库目录只包含postgis-3.so。但是如何告诉我的函数使用这个呢?

我已经找到了一个技巧,创建了一个名为postgis-2.1.so的链接,并指向postgis-3.so。但这确实是一个丑陋的做法,我不想创建一个新的链接,每次我将升级后。

我还试图转储函数,对其进行如下的编辑和还原:

代码语言:javascript
复制
pg_dump -U postgres -Fc -s -f db_schema my_db
sed -i -e 's/postgis-2.1/postgis-3/g' db_schema
pg_restore -l db_schema | grep FUNCTION > functions
pg_restore -U postgres -d my_db -L functions db_schema

但是pg_restore似乎不喜欢我看到这个文件的事实,因为我得到了这个错误:

pg_restore:自定义存档程序无法从输入文件读取:文件结束

是否有一种干净的方法来进行这个升级,还是我的符号链接是这里唯一的解决方案?

EN

回答 1

Stack Overflow用户

发布于 2020-07-08 13:55:56

你试过跟踪文档

你好像很想念启用PostGIS

代码语言:javascript
复制
-- Enable PostGIS (as of 3.0 contains just geometry/geography)
CREATE EXTENSION postgis;
-- enable raster support (for 3+)
CREATE EXTENSION postgis_raster;
-- Enable Topology
CREATE EXTENSION postgis_topology;
-- Enable PostGIS Advanced 3D
-- and other geoprocessing algorithms
-- sfcgal not available with all distributions
CREATE EXTENSION postgis_sfcgal;
-- fuzzy matching needed for Tiger
CREATE EXTENSION fuzzystrmatch;
-- rule based standardizer
CREATE EXTENSION address_standardizer;
-- example rule data set
CREATE EXTENSION address_standardizer_data_us;
-- Enable US Tiger Geocoder
CREATE EXTENSION postgis_tiger_geocoder;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62778486

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档