shp2pgsql 导入 Shp 到 PostGIS 空间数据库

news2025/5/25 4:18:33

前言

shp2pgsqlPostGIS自带的命令行工具,用于将Shapefile文件声称SQL脚本导入到PostGIS空间数据库。

1. 安装 PostGIS

通过Application Stack Builder或者下载单独的PostGIS包进行安装。shp2pgsql则是与PostGIS工具集成在一起,无需单独下载。该命令行工具可以在安装路径下的bin目录中找到。

也可以打开shp2pgsql图形界面工具,也就是上一节中的PostGIS Bundle for PostgreSQL来导入Shp数据。

2. shp2pgsql 选项参数

基本语法:

shp2pgsql [OPTIONS] shapefile路径 [schema.]table > roads.sql(输出SQL路径)

shp2pgsql [OPTIONS] shapefile路径 [schema.]table

选项介绍:

选项名称

选项描述

选项示例

-c|-a|-d|-p

互斥选项,只能选择一个

  • -c:创建新表并从Shapefile填充它。这是默认模式
  • -a:将Shapefile中的数据追加到数据库表中。要主义的是使用此选项加载多个文件,这些文件必须具有相同的属性和相同的数据类型。
  • -d:在使用Shapefile中的数据创建新表之前,先删除数据库表。
  • -p:只生成表创建SQL代码,不添加任何实际数据。如果需要完全分离表创建和数据加载步骤,可以使用此方法。

shp2pgsql -c -D -s 4269 -i -I shaperoads.shp myschema.roadstable > roads.sql

-D

输出数据使用PostgreSQL“转储”格式。这可以与-a、-c-d组合使用。它的加载速度比默认的“插入”SQL格式快得多。将其用于非常大的数据集。

-s [<FROM_SRID>:]<SRID>

使用指定的SRID创建并填充几何图形表。可选地指定输入shapefile使用给定的FROM_SRID,在这种情况下,几何图形将被重新投影到目标SRID

shp2pgsql -s 4326 C:countries.shp public.countriesSQL>C:countries.sql

-k

保持标识符的大小写(列、模式和属性)。请注意,Shapefile中的属性都是大写的。

-i

将所有整数强制转换为标准的32位整数,即使DBF标头签名似乎保证了这一点,也不要创建64位大整数。

-I

在几何体列上创建GiST索引。

-m

-m a_file_name指定一个文件,其中包含一组(长)列名到10个字符的DBF列名的映射。文件的内容是一行或多行两个名称,用空格分隔,没有尾随或前导空格。

例如:

COLUMNNAME DBFFIELD1

AVERYLONGCOLUMNNAME DBFFIELD2

-S

生成简单的几何图形,而不是MULTIPOLYGON。只有当所有几何体实际上都是单一的(即具有单个壳的多边形,或具有单个顶点的多边形)时,才能成功。

-t <dimensionality>

强制输出几何体具有指定的维度。使用以下字符串表示维度:2D、3DZ、3DM、4D。

如果输入的维度比指定的少,则输出将用零填充这些维度。如果输入具有指定的更多尺寸,则不需要的尺寸将被删除。

-w

输出WKT格式,而不是WKB。请注意,由于精度损失,这可能会引入坐标漂移。

-e

不使用事务,单独执行每条语句。当存在一些会产生错误的不良几何形状时,这允许加载大多数好数据。请注意,这不能与-D标志一起使用,因为“转储”格式总是使用事务。

-W

指定输入数据的编码(dbf文件)。使用时,dbf的所有属性都会从指定的编码转换为UTF8。生成的SQL输出将包含一个SET CLIENT_ENCODING to UTF8命令,以便后端能够从UTF8重新转换为数据库内部配置使用的任何编码。

shp2pgsql -s 4326 -I -W "UTF-8" C:countries.shp public.countriesSQL>C:countries.sql

-N <policy>

NULL几何处理策略(insert*,skip,abort

-n

-n仅导入DBF文件。如果您的数据没有相应的shapefile,它将自动切换到此模式并仅加载dbf。因此,只有当您有一个完整的shapefile集,并且只需要属性数据而不需要几何体时,才需要设置此标志。

-G

WGS84长纬度(SRID=4326)中使用地理类型而不是几何形状(需要经度/纬度数据)

-T <tablespace>

指定新表的表空间。除非同时使用-X参数,否则索引仍将使用默认表空间。PostgreSQL文档对何时使用自定义表空间有很好的描述。

-X <tablespace>

为新表的索引指定表空间。这适用于主键索引,也适用于GIST空间索引if -I

-Z

使用此标志时,将阻止生成ANALYZE语句。如果没有-Z标志(默认行为),将生成ANALYZE语句。

-?

显示帮助

shp2pgsql -?

可以在命令行窗口中查看完整选项参数:![](https://i-blog.csdnimg.cn/img_convert/768b24d062237d63c0ce08b65619e46b.png)

3. shp2pgsql 使用示例

直接导入到数据库:

shp2pgsql -s 4326 -I -W "UTF-8" C:\Users\hasee\Desktop\conutries\countries.shp public.countries | psql -U postgres -d geodata

其中postgres数据库用户名,geodata为数据库名称。

通过SQL导入数据库:

shp2pgsql -s 4326 -I -W "UTF-8" C:\Users\hasee\Desktop\conutries\countries.shp public.countriesSQL>C:\Users\hasee\Desktop\conutries\countries.sql

数据库示例图片

OpenLayers示例数据下载,请回复关键字:ol数据

全国信息化工程师-GIS 应用水平考试资料,请回复关键字:GIS考试

GIS之路 已经接入了智能助手,欢迎大家前来提问。

欢迎访问我的博客网站-长谈GIShttp://shanhaitalk.com

都看到这了,不要忘记点赞、收藏 + 关注

本号不定时更新有关 GIS开发 相关内容,**欢迎关注 !

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

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

相关文章

word设置如“第xx页 共xx页”格式的页码

问题1&#xff1a; 为word文档设置如“第xx页 共xx页”格式的页码。 解决方法&#xff1a; 1、鼠标双击页脚位置进入页脚编辑模式&#xff1b; 2、在页脚处输入“第 页 共 页”内容并居中&#xff1b; 3、将光标放在“第 页”之间并插入“Page”&#xff0c;执行操作“…

DL00912-基于自监督深度聚类的高光谱目标检测含数据集

在科研的道路上&#xff0c;数据的获取与分析无疑是成功的关键。对于从事高光谱数据研究的你&#xff0c;我们为您带来了一款革命性的工具——基于自监督深度聚类的高光谱目标检测系统。 完整代码数据集见文末 这款系统通过最先进的自监督学习技术&#xff0c;结合深度聚类算…

Runtipi - 开源个人家庭服务器管理工具

项目功能&#xff1a;家庭服务器管理 ▎项目介绍&#xff1a; 一个开源的个人家庭服务器管理工具&#xff0c;旨在简化在单一服务器上管理和运行多个服务的过程。 它基于 Docker 构建&#xff0c;提供了一个简单的 Web 界面&#xff0c;用户可以通过该界面轻松添加和管理服务…

HJ106 字符逆序【牛客网】

文章目录 零、原题链接一、题目描述二、测试用例三、解题思路四、参考代码 零、原题链接 HJ106 字符逆序 一、题目描述 二、测试用例 三、解题思路 基本思路&#xff1a;   考虑到可能会有多个空格&#xff0c;使用使用 getline 函数直接读取一行。   如果可以直接打印的…

力扣HOT100之二叉树: 236. 二叉树的最近公共祖先

果然&#xff0c;这道题二刷还是不会做&#xff0c;回去看卡尔视频了。结合灵神的题解&#xff0c;我对这道题有了一些新的理解。 首先这道题还是用递归来做&#xff0c;由于我们需要计算两个节点的最近公共祖先&#xff0c;一定是从下往上来遍历&#xff0c;只有先判断左右子树…

腾讯音乐一面

1、自我介绍项目&#xff08;省略&#xff09; 2、为什么存储要从TiDB迁移到Mysql&#xff1f; TiDB 迁移至 MySQL 核心原因总结&#xff1a; 成本优化 TiDB 需多节点集群&#xff08;PD/TiKV/TiDB Server&#xff09;&#xff0c;硬件、运维及学习成本高。中小业务&#xff08…

Pluto实验报告——基于2ASK的简易的通信系统

一、实验目的 1. 熟悉并掌握PLUTO SDR 主动学习模块的使用&#xff1b; 2.通过matlab 编码与adalm pluto 相配合达成一个简易的通信系统&#xff0c;并能 够传输一些较为简单的信息。 二、实验原理 2ASK 调制原理&#xff1a; 振幅键控是指利用载波的振幅变化来传递数字基带信…

深入了解redis的哈希槽的知识

目录 1、哈希算法分类 1.1、简单哈希算法 1.2、一致性哈希算法 1、原理&#xff1a; 2、解决问题 3、数据倾斜问题 4、虚拟节点 2. 哈希槽 2.1、介绍 2. 2、作用 1、数据分片&#xff08;Sharding&#xff09; 2、高可用性&#xff08;HA&#xff09; 3…

农业机械化、电气化和自动化知网英文普刊:1天录用,2周见刊发表!

CSP科学出版社&#xff0c;旨在通过为研究人员提供最佳环境来发表、参考、阅读和引用他们的作品&#xff0c;从而为科学界服务。现已与科检易学术达成出版战略合作&#xff0c;现在联合共同出版高质量学术水平的期刊&#xff0c;为方便广大科研学者投稿方便&#xff0c;现已经建…

Docker-Compose使用自定义网桥后在OpenWrt系统中容器无法访问网络解决方案

Docker-Compose使用自定义bridge网桥后在OpenWrt系统中容器无法访问网络解决方案 示例compose描述文件如下&#xff0c;注意最后网络配置&#xff1a; # docker-compose --env-file .env.yoko.prod.local up -d services:...postgres:image: kuluseky/postgres-zhparser-post…

界面组件DevExpress WPF中文教程:Grid - 行和卡片

DevExpress WPF拥有120个控件和库&#xff0c;将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序&#xff0c;这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件…

Qt enabled + geometry 属性(2)

文章目录 enabled属性可用与禁用的概念API接口代码演示 阐述说明1. 先简单描述下要如何演示出上面两个接口的效果&#xff08;思路&#xff09;2. 事先规范按钮对象的命名3. 定义两个按钮对象的槽函数 动图演示效果4. widget.cpp geometry属性预备知识API接口上下左右移动 ta…

Llamaindex自学笔记(完)

Llamaindex框架主要做RAG&#xff0c;工作流用LangGraph做 换源&#xff1a; -i https://pypi.mirrors.ustc.edu.cn/simple/环境搭建&#xff1a; conda create -n llamaindex python3.12 conda activate llamaindexpip install llama-index pip install llama-cloud-servic…

飞书知识问答深度测评:企业AI应用落地的“范本级”产品

前言 当 AI 逐渐从技术前沿走向日常办公&#xff0c;我们最常听到的一个词是“效率提升”。但真正能做到降本增效、让企业员工切实受益的 AI 产品&#xff0c;仍属少数。尤其是在组织内部知识管理这一块&#xff0c;大多数企业仍停留在“搜索靠关键词、记录靠记忆、协作靠问人…

draw.io的基础与进阶使用指南

前言 一、Draw.io 简介 Draw.io 是一款功能强大的绘图工具&#xff0c;支持在线使用和本地安装。它提供了丰富的模板和形状元素&#xff0c;能够绘制流程图、UML 图、甘特图、网络图等多种图形。Draw.io 的文件格式支持可编辑的矢量图和位图&#xff0c;方便后续修改 draw.io的…

Sanitizers

一、简介 sanitizers 是谷歌提供的一套开源工具&#xff0c;能够发现堆栈读写溢出、内存泄漏、线程数据竞争和死锁等问题。包括&#xff1a; AddressSanitizers (Asan):检测地址相关问题&#xff0c;如use-after-free,heap-buffer-overflow, stack_buffer_overflow,use_after_…

pip代理出现问题 ProxyError

WARNING: Retrying (Retry(total4, connectNone, readNone, redirectNone, statusNone)) after connection broken by ‘ProxyError(‘Cannot connect to proxy.’, NewConnectionError(’<pip._vendor.urllib3.connection.HTTPSConnection object at 0x7f8347ad5ae0>: F…

vue+threeJS 创建镂空球体(SphereGeometry)

嗨&#xff0c;我是小路。今天主要和大家分享的主题是“vuethreeJS 创建镂空球体&#xff08;SphereGeometry&#xff09;”。 上次看到一个做镂空球体的项目&#xff0c;自己也准备尝试着做一做。今天终于做完了&#xff0c;并对这个项目进行梳理。 镂空球体示例效果…

[ Qt ] | 常见控件(一)

目录 Widget enable geometry 标题中的&#xff1a;有一不一定有二&#xff0c;但是有一说明还没结束。 Widget 控件(Widget)&#xff0c;是界面上各种元素&#xff0c;各种部分的统称。 Qt中的控件都是继承自QWidget这个类&#xff0c;是Qt控件体系中&#xff0c;通用的…

【八股战神篇】Java虚拟机(JVM)高频面试题

目录 专栏简介 一 请解释Java虚拟机(JVM)及其主要功能 延伸 1. JVM的基本概念 2. JVM的主要功能 二 对象创建的过程了解吗 延伸 1.Java 创建对象的四种常见方式 三 什么是双亲委派模型 延伸 1.双亲委派机制的作用: 2.双亲委派模型的核心思想: 3.双亲委派模型的…