当前位置: 首页 > article >正文

shp2pgsql 导入 Shp 到 PostGIS 空间数据库

前言

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开发 相关内容,**欢迎关注 !

相关文章:

shp2pgsql 导入 Shp 到 PostGIS 空间数据库

前言 ❝ shp2pgsql是PostGIS自带的命令行工具&#xff0c;用于将Shapefile文件声称SQL脚本导入到PostGIS空间数据库。 1. 安装 PostGIS 通过Application Stack Builder或者下载单独的PostGIS包进行安装。而shp2pgsql则是与PostGIS工具集成在一起&#xff0c;无需单独下载。该命…...

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

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

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

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

PostgreSQL架构

目录 一、PostgreSQL核心特性与优势 1.PostgreSQL简介 2.PostgreSQL的核心特点 &#xff08;1&#xff09;开源与自由 &#xff08;2&#xff09;高度符合SQL标准 &#xff08;3&#xff09;丰富的数据类型 &#xff08;4&#xff09;事务与并发控制 &#xff08;5&…...

文章记单词 | 第111篇(六级)

一&#xff0c;单词释义 damage /ˈdmɪdʒ/ v./n. 损害&#xff1b;损坏&#xff1b;损失harbour /ˈhɑːbə(r)/ n. 港口&#xff1b;港湾 v. 庇护&#xff1b;窝藏&#xff08;美式拼写&#xff1a;harbor&#xff09;gasp /ɡsp/ v. 喘气&#xff1b;喘息 n. 喘息&#x…...

在Java中,将Object对象转换为具体实体类对象

在Java中&#xff0c;将Object对象转换为具体实体类对象可以通过以下几种方法实现&#xff1a; 1‌.使用instanceof关键字进行类型检查和转换‌&#xff1a; 首先&#xff0c;使用instanceof关键字检查Object对象是否为目标实体类的类型。 如果是&#xff0c;则进行强制类型…...

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

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

Vue3和React中插件化设计思想

Vue 3 和 React 都广泛支持插件化设计思想&#xff0c;但因为它们的架构和理念不同&#xff0c;插件化的实现方式也不尽相同。以下分别详细讲解这两者中如何实现插件化&#xff1a; &#x1f7e9; 一、Vue 3 中的插件化实现 Vue 3 继承了 Vue 2 的插件机制&#xff0c;同时增强…...

基于ResNet的医学影像辅助诊断系统

源码下载地址: https://download.csdn.net/download/shangjg03/90873910 1. 简介 医学影像辅助诊断系统是利用计算机视觉和深度学习技术,帮助医生分析医学影像(如X光、CT、MRI等)并提供诊断建议的系统。本教程将开发一个基于ResNet的胸部X光肺炎检测系统。 2. 准备工作...

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…...

【PhysUnits】4.4 零类型(Z0)及其算术运算(zero.rs)

一、源码 该代码定义了一个类型系统中的零类型Z0&#xff0c;并为其实现了基本的算术运算&#xff08;加法、减法、乘法、除法&#xff09;。这是一个典型的类型级编程示例&#xff0c;使用Rust的类型系统在编译期进行数学运算。 //! 零类型(Z0)及其算术运算实现 //! //! 本…...

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

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

Python排序函数全面指南:从基础到高级

文章目录 Python排序函数全面指南&#xff1a;从基础到高级1. 两种主要排序方式2. 基本参数详解2.1 key参数&#xff1a;自定义排序规则2.2 reverse参数&#xff1a;控制排序方向 3. 高级排序技巧3.1 多级排序3.2 稳定排序 4. 性能考虑5. 特殊排序场景5.1 对自定义对象排序5.2 …...

深入了解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;现已经建…...

java将rtsp转成flv在浏览器播放

1、添加maven依赖 <dependency> <groupId>io.github.javpower</groupId> <artifactId>rtsp-converter-flv-spring-boot-starter</artifactId> <version>1.5.9.2</version> </dependency> 2、在配置application.yml&#xff…...

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…...

安全生态与职业跃迁

18. 网络安全产业生态 18.1 全球安全产业链解析 核心参与者角色 安全厂商&#xff1a; 终端安全&#xff1a;CrowdStrike、SentinelOne&#xff08;EDR/XDR&#xff09; 网络防御&#xff1a;Palo Alto Networks、Fortinet&#xff08;NGFW/SASE&#xff09; 云安全&#…...

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

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

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

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

clang的介绍与使用

一、Clang 简介 Clang 是一个开源的 C/C/Objective-C 编译器前端&#xff0c;基于 LLVM&#xff08;Low Level Virtual Machine&#xff09; 项目开发。它被设计为替代传统 GCC 的现代化编译器&#xff0c;具有以下特点&#xff1a; 高性能&#xff1a;编译速度快&#xff0c…...

GD32 IIC(I2C)通信(使用示例为SD2068)

一、前言 最近需要用到GD32的I2C通信&#xff0c;虽然是第一次做I2C通信&#xff0c;但是GD32完整的标准库有现存的I2C通信示例&#xff0c;虽然示例是EEPROM的通信&#xff0c;但是调用的函数应该是大差不差&#xff0c;所以上手比较简单&#xff0c;这里简单记录一下笔记&…...

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…...

Ubuntu-多显示器黑屏问题及nvidia显卡驱动安装

Ubuntu-多显示器黑屏问题及nvidia显卡驱动安装 多显示器黑屏问题查看系统显卡信息多显示器黑屏问题 当通过HDMI为Ubuntu加入显示器时,发现新加入的显示器黑屏,更改设置里的显示器属性也无法解决。 该黑屏的原因是系统没有安装显卡驱动,因此需要安装驱动。 查看系统显卡信息…...