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

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

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

相关文章

【ISP算法精粹】什么是global tone mapping和local tone mapping?

1. 简介 全局色调映射&#xff08;Global Tone Mapping&#xff09;和局部色调映射&#xff08;Local Tone Mapping&#xff09;是高动态范围&#xff08;HDR&#xff09;图像处理中的两种关键技术&#xff0c;用于将高动态范围图像的亮度值映射到标准动态范围&#xff08;LDR…

虚拟环境中VSCode运行jupyter文件

用VS Code打开jupyter文件&#xff0c;点击右上角 Select Kernel 在正上方会出现这个选择框&#xff0c;选择 Python Environment 会出来所有的虚拟环境&#xff0c;选择要用的环境行

如何计算VLLM本地部署Qwen3-4B的GPU最小配置应该是多少?多人并发访问本地大模型的GPU配置应该怎么分配?

本文一定要阅读我上篇文章&#xff01;&#xff01;&#xff01; 超详细VLLM框架部署qwen3-4B加混合推理探索&#xff01;&#xff01;&#xff01;-CSDN博客 本文是基于上篇文章遗留下的问题进行说明的。 一、本文解决的问题 问题1&#xff1a;我明明只部署了qwen3-4B的模型…

antv/g6 图谱封装配置(二)

继上次实现图谱后&#xff0c;后续发现如果要继续加入不同样式的图谱实现起来太过麻烦&#xff0c;因此考虑将配置项全部提取封装到js文件中&#xff0c;图谱组件只专注于实现各种不同的组件&#xff0c;其中主要封装的点就是各个节点的横坐标&#xff08;x&#xff09;,纵坐标…

从芯片互连到机器人革命:英伟达双线出击,NVLink开放生态+GR00T模型定义AI计算新时代

5月19日&#xff0c;在台湾举办的Computex 2025上&#xff0c;英伟达推出新技术“NVLink Fusion”&#xff0c;允许非英伟达CPU和GPU&#xff0c;同英伟达产品以及高速GPU互连技术NVLink结合使用&#xff0c;加速AI芯片连接。新技术的推出旨在保持英伟达在人工智能开发和计算领…

Qt window frame + windowTitle + windowIcon属性(3)

文章目录 window frame属性window frame的概念1. window frame的影响2. 图片演示3. 代码演示 API接口widget.cpp&#xff08;测试代码&#xff09; windowTitle属性API接口问题 注意点widget.cpp&#xff08;属性用法&#xff09; windowIcon属性API接口啥是窗口图标玩法1. 先…

Git 分支管理:merge、rebase、cherry-pick 的用法与规范

Git 分支管理&#xff1a;merge、rebase、cherry-pick 的用法与规范 在团队开发和个人项目中&#xff0c;合理管理 Git 分支至关重要。merge、rebase 和 cherry-pick 是最常用的三种分支操作命令。本文将介绍它们的基本用法、适用场景及最佳实践规范&#xff0c;帮助大家更高效…

VR全景制作方法都有哪些?需要注意什么?

VR全景制作是将线下实景场景转化为具有沉浸式体验的全景图像的相关技术流程。通过图像处理和软件拼接等手段及技术&#xff0c;可以制作出VR全景图。后面&#xff0c;我们科普详细的VR全景制作方法指南&#xff0c;顺便介绍众趣科技在相关领域提供的支持方案。 选定拍摄地点与准…

计算机系统结构1-3章节 期末背诵内容

Amdahl定律: 加快某部件执行速度所能获得的系统性能加速比&#xff0c;受限于该部件的执行时间占系统中总执行时间的百分比。 加速比依赖于: 可改进比例&#xff1a;在改进前的系统中&#xff0c;可改进部分的执行时间在总的执行时间中所占的比例。 部件加速比&#xff1a;可改…

JS实现直接下载PDF文件

pdf文件通过a标签直接下载会打开页面&#xff0c;所以&#xff0c;请求该文件的blob文件流数据&#xff0c;再通过window.URL.createObjectURL转成链接&#xff0c;就可以直接下载了。 只需要替换url和文件名称就行&#xff0c;文件名的后缀记得要写上pdf&#xff0c;不然会变成…

深度解析Pytest中Fixture机制与实战案例

一、为什么我们需要Fixture&#xff1f; 在某次金融系统重构项目中&#xff0c;我们的测试团队曾遇到这样的困境&#xff1a;随着测试用例增长到500&#xff0c;使用unittest框架编写的测试代码出现了严重的维护问题——setup方法臃肿不堪&#xff0c;测试数据混乱&#xff0c…

文档结构化专家:数字化转型的核心力量

文档结构化专家:定义、职责与行业应用的全方位解析 一、文档结构化的定义与核心价值 文档结构化是将非结构化或半结构化文档(如文本、图像、表格)转换为计算机可处理的规范化数据形式的过程。其核心在于通过语义解析、信息单元划分和标准化格式(如XML/JSON),实现信息的…

Linux系统管理与编程16番外篇:PXE自动化安装部署OpenEuler24.03LTS

兰生幽谷&#xff0c;不为莫服而不芳&#xff1b; 君子行义&#xff0c;不为莫知而止休。 Preboot Execution Environment 本机服务器操作系统&#xff1a;CentOS7.9.2207 目标服务器安装系统&#xff1a;openEuler-24.03-LTS-SP1-everything-x86_64-dvd.iso 虚拟机&#xff1…

Enhanced RTMP H.265(HEVC)技术规格解析:流媒体协议的新突破

Enhanced RTMP H.265&#xff08;HEVC&#xff09;技术规格解析&#xff1a;流媒体协议的新突破 “每一帧画面都是时间的映射&#xff0c;压缩之后的灵魂&#xff0c;依然能栩栩如生。” 随着流媒体技术的快速发展&#xff0c;视频编码标准不断推陈出新。H.264/AVC虽然已经成为…

Visual Studio Code 改成中文模式(汉化)

1、打开工具软件&#xff08;双击打开&#xff09; 2、软件左边图标点开 3、在搜索框&#xff0c;搜索 chinese 出现的第一个 就是简体中文 4、点击第一个简体中文&#xff0c;右边会出来基本信息 点击 install 就可以安装了&#xff08;记得联网&#xff09;。 5、安装完右…

Linux--初识文件系统fd

01. C/系统调用文件操作 C/系统调用文件操作 02. 文件系统(ext2)结构 Linux ext2文件系统&#xff0c;上图为磁盘文件系统图&#xff08;内核内存映像肯定有所不同&#xff09;&#xff0c;磁盘是典型的块设备&#xff0c;硬盘分区被划分为一个个的block。一个块的大小(有1MB,…

算法中的数学:欧拉函数

1.相关定义 互质&#xff1a;a与b的最大公约数为1 欧拉函数&#xff1a;在1~n中&#xff0c;与n互质的数的个数就是欧拉函数的值 eg&#xff1a; n1时&#xff0c;欧拉函数的值为1&#xff0c;因为1和1是互质的 n2是&#xff0c;值为2&#xff0c;因为1和2都是互质的 积性函数&…

BaseDao指南

1. BaseDao类 import java.sql.*;/*** 通用的工具类 ,负责连接数据&#xff0c; 执行增删改查的通用方法*/ public class BaseDao {private Connection connection;private PreparedStatement pstm;private ResultSet rs;/*** 建立数据库连接** return*/public Boolean getCon…

SpringBoot JAR 启动原理

文章目录 版本概述JAR 包结构MANIFEST.MF 描述文件JarLauncherArchive 接口launch 方法Handlers.register() 方法getClassPathUrls 方法createClassLoader 方法 时序图参考 版本 Java 17SpringBoot 3.2.4 概述 JAR 启动原理可以简单理解为“java -jar的启动原理” SpringBo…

YOLO11解决方案之速度估算探索

概述 Ultralytics提供了一系列的解决方案&#xff0c;利用YOLO11解决现实世界的问题&#xff0c;包括物体计数、模糊处理、热力图、安防系统、速度估计、物体追踪等多个方面的应用。 YOLO速度估算结合物体检测和跟踪技术&#xff0c;使用YOLO11 模型检测每帧中的物体&#xf…