WKT数据示例并与GeoJSON数据对比

WKT(Well-Known Text) 是 OGC(开放地理空间联盟)标准定义的一种文本格式,用来表示空间几何数据。达梦、PostgreSQL(PostGIS)、MySQL 等数据库都支持它。

与 GeoJSON 的对应关系

java 复制代码
GeoJSON(前端用)          ↔       WKT(数据库存)
{"type":"Point",...}      ↔     POINT (...)
{"type":"LineString",...} ↔     LINESTRING (...)
{"type":"Polygon",...}    ↔     POLYGON ((...))

关键在于:GeoJSON 用 [] 包坐标,WKT 用 () 包坐标,且 WKT 里经纬度之间是空格不是逗号。

各种类型的 WKT 示例

1. Point(点)

java 复制代码
POINT (113.324568 23.106682)

注:WKT 里经纬度之间用空格 ,GeoJSON 用逗号

2. LineString(线串)

java 复制代码
LINESTRING (113.1 23.0, 113.15 23.05, 113.2 23.1)

3. Polygon(多边形)

java 复制代码
POLYGON ((113.2 23.0, 113.4 23.0, 113.4 23.2, 113.2 23.2, 113.2 23.0))

首尾相同才能闭合,用双层括号,外面那层是面的边界,里面可以有多个环。

4. Polygon 带洞(有内环)

java 复制代码
POLYGON (
    (0 0, 10 0, 10 10, 0 10, 0 0),       -- 外环:逆时针
    (2 2, 2 8, 8 8, 8 2, 2 2)            -- 内环:顺时针(洞)
)

第二个括号内环是个"洞",环内不算是多边形区域。

5. MultiPoint(多点)

java 复制代码
MULTIPOINT ((113.32 23.10), (113.33 23.11), (113.34 23.12))

6. MultiLineString(多线串)

java 复制代码
MULTILINESTRING ((113.1 23.0, 113.2 23.1), (113.3 23.2, 113.4 23.3))

7. MultiPolygon(多多边形)

java 复制代码
MULTIPOLYGON (((113.2 23.0, 113.3 23.0, 113.3 23.1, 113.2 23.1, 113.2 23.0)), ((113.4 23.2, 113.5 23.2, 113.5 23.3, 113.4 23.3, 113.4 23.2)))

三层括号:最外是 MultiPolygon → 中间是每个 Polygon → 最内是坐标环。

8. GeometryCollection(几何集合)

java 复制代码
GEOMETRYCOLLECTION (POINT (113.32 23.10), LINESTRING (113.1 23.0, 113.2 23.1))

WKT vs GeoJSON 对比速查

对比项 WKT(数据库) GeoJSON(前端)
坐标分隔符 空格 逗号
括号 () []
顺序 经度在前,纬度在后(都一样)
存储场景 达梦 ST_Geometry 字段 Leaflet 传给后端

项目中怎么用

java 复制代码
// 从数据库读到的 WKT
String wktFromDb = "LINESTRING (113.1 23.0, 113.15 23.05, 113.2 23.1)";

// 转成 GeoJSON 返回给前端
String geoJson = GeoSpatialUtil.wktToGeoJson(wktFromDb);
// → {"type":"LineString","coordinates":[[113.1,23.0],[113.15,23.05],[113.2,23.1]]}

// 前端传来的 GeoJSON 转 WKT 存库
String wktToDb = GeoSpatialUtil.geoJsonToWkt(geoJson);
// → LINESTRING (113.1 23.0, 113.15 23.05, 113.2 23.1)
相关推荐
Darling噜啦啦6 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠7 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾7 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8217 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q7 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒7 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记7 天前
单项不带头不循环链表
数据结构·链表
小糯米6018 天前
JS 数组
数据结构·算法·排序算法
小欣加油8 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒8 天前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode