首页 > 基础资料 博客日记
SHP文件与PostGIS数据库Geom字段:WKT和EWKB相互转换SQL
2026-05-15 14:00:02基础资料围观1次
SHP文件与PostGIS数据库Geom字段:WKB/EWKB高精度互转最全踩坑总结
一、前言
在GIS业务开发中,经常遇到一个核心需求:拿到SHP原始矢量,精准对应数据库中Geom原始存储值。
很多人分不清:WKT、WKB、EWKB,经常出现导出坐标精度丢失、二进制串对不上等问题。
本文结合真实实操踩坑,一次性讲透:
-
为什么SHP肉眼坐标一样,二进制Geom却不一样?
-
PostGIS真实存储格式是什么?
-
如何高精度正向生成数据库原生EWKB串?
-
如何从十六进制Geom逆推原始高精度坐标?
-
精准实现Hex与高精度坐标互相转换
二、三种几何格式通俗区分(重点)
1、WKT(人看的明文)
示例:POINT \(107\.503611000347 35\.6885570000056\)
特点:可读、简单、不带坐标系。
2、WKB(标准二进制)
示例:0101000000fab9a1293be05a404837c2a222d84140
特点:纯几何,不带SRID坐标系,PostGIS不原生存储这种。
3、EWKB(PostGIS真实存储格式)⭐重点
示例:0101000020E6100000FCB9A1293BE05A405037C2A222D84140
多出一段:20E6100000 = SRID=4326
结论:PostGIS库里Geom字段存的全部是EWKB,不是WKB。
三、最容易踩的坑(你今天全部遇到过)
坑1:小数点位数不同,二进制完全不同
看上去几乎一样的坐标:
-
原始高精度:
POINT \(107\.503611000347 35\.6885570000056\) -
四舍五入后:
POINT \(107\.503611 35\.688557\)
二进制EWKB完全不一样,绝对不能混用。
原因:浮点二进制存储极其敏感,哪怕末尾0.0000000001差异,Hex串完全改变。
坑2:QGIS导出WKT默认丢精度
QGIS导出CSV时,自动压缩小数位,永远得不到SHP原生高精度坐标,所以转出来Hex永远和数据库对不上。
四、生产通用万能SQL(可直接收藏)
1、正向生成:高精度EWKB(和数据库一模一样)
-- WKT 转 PostGIS 原生存储 EWKB 十六进制
SELECT encode(
ST_AsEWKB(
ST_SetSRID(ST_GeomFromText('POINT (107.503611000347 35.6885570000056)'),4326)
),'hex'
) AS geom_hex;
2、逆向解析:Hex原始Geom逆推高精度WKT
解决endian报错、唯一正确写法
-- EWKB十六进制 逆推 原始高精度坐标
SELECT ST_AsText(
ST_GeomFromEWKB(
decode('0101000020E6100000A428756E7F145840C0D39D279E454440', 'hex')
)
) AS wkt_point;
3、批量解析库里所有Geom(生产常用)
SELECT
id,
ST_AsText(ST_GeomFromEWKB(decode(geom, 'hex'))) AS wkt_point
FROM 你的表名;
五、如何拿到SHP原生高精度Hex(不用计算)
最稳定、零误差方案:超图iDesktop
-
SHP导入UDB文件数据源(不要直接进数据库)
-
打开属性表
-
查看Shape 字段
-
该字段值 = 数据库真实存储EWKB
✅ 无需转换、无精度丢失、完全一致。
六、最终总结(最简背诵版)
-
数据库存的是EWKB,带4326坐标系头;
-
坐标小数少一位,Hex完全不一样;
-
QGIS导出WKT会丢精度,不可用于比对;
-
逆推Hex必须加 decode(xxx,'hex'),否则endian报错;
-
想要原始Geom,优先超图Shape字段,不要手动算。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
上一篇:Spring AI 2.0 GA 倒计时:先别急,来看看 Java AI 框架的另一条路
下一篇:没有了
相关文章
最新发布
- SHP文件与PostGIS数据库Geom字段:WKT和EWKB相互转换SQL
- Spring AI 2.0 GA 倒计时:先别急,来看看 Java AI 框架的另一条路
- HEIC 批量转 JPG - 一键转换苹果 HEIC 格式为 JPG/PNG,保留 EXIF 信息,支持批量处理
- 【php】老旧PHP项目(PHP 5.6)本地环境搭建与踩坑记录
- Vue3 轻量安全滑动拼图验证码:vue-sliding-puzzle 上手全攻略
- 多市场行情时间戳对齐:UTC 存储的夏令时陷阱与数据库设计方案
- 15. 别再硬写提示词了!LangChain ChatPromptTemplate核心实战
- 一次 OOM 线上排查实录
- 从控制论看 Harness Engineering:当反馈回路终于能在"重要的地方"闭合
- AI 测试全场景提效:功能 / 性能 / 安全 / 自动化,用 AI 重塑测试工作流

