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)
相关推荐
风筝在晴天搁浅1 小时前
快手 CodeTop LeetCode 224.基本计算器
数据结构·算法·leetcode
牢姐与蒯2 小时前
c++数据结构之c++11(一)
数据结构·c++
iiiiyu2 小时前
IO流(二)
java·开发语言·数据结构·编程语言
啦啦啦啦啦zzzz2 小时前
数据结构:平衡二叉树
数据结构·c++·二叉树
Ameilide5 小时前
数据结构 树 二叉树
数据结构
WWW65265 小时前
代码随想录 打卡第四十七天
数据结构·算法·leetcode
cpp_25016 小时前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
c238566 小时前
map和set
数据结构·c++
小欣加油8 小时前
leetcode239 滑动窗口最大值
数据结构·c++·算法·leetcode·哈希算法