TDengine 地理函数 ST_GeomFromText 用户手册

ST_GeomFromText 函数

基本信息

  • 语法:ST_GeomFromText(wkt_expr)
  • 作用:将 Well-Known Text (WKT) 字符串转换为 GEOMETRY 类型并存储为二进制。
  • 返回类型:GEOMETRY
  • 适用类型:VARCHAR(输入 WKT)
  • 适用表:表、超级表
  • 支持的 WKT 类型:POINT / LINESTRING / POLYGON / MULTIPOINT / MULTILINESTRING / MULTIPOLYGON / GEOMETRYCOLLECTION

常用 WKT 示例

sql 复制代码
-- 点
ST_GeomFromText('POINT(116.397 39.908)')

-- 线串
ST_GeomFromText('LINESTRING(116.39 39.90,116.40 39.91,116.41 39.92)')

-- 简单多边形(闭合,首尾一致)
ST_GeomFromText('POLYGON((0 0,4 0,4 3,0 3,0 0))')

-- 带洞多边形(外环 + 内环)
ST_GeomFromText('POLYGON((0 0,6 0,6 6,0 6,0 0),(2 2,4 2,4 4,2 4,2 2))')

-- 多点
ST_GeomFromText('MULTIPOINT((0 0),(1 1),(2 2))')

-- 多线串
ST_GeomFromText('MULTILINESTRING((0 0,1 1),(2 2,3 3,4 4))')

-- 多多边形
ST_GeomFromText('MULTIPOLYGON(((0 0,2 0,2 2,0 2,0 0)),((3 3,5 3,5 5,3 5,3 3)))')

-- 几何集合(混合类型)
ST_GeomFromText('GEOMETRYCOLLECTION(POINT(1 1),LINESTRING(0 0,2 2))')

基础用法示例

sql 复制代码
-- 建表:包含 GEOMETRY 列
CREATE TABLE geo_points (
  ts TIMESTAMP,
  name VARCHAR(64),
  geom GEOMETRY(256)
);

-- 插入点数据
INSERT INTO geo_points VALUES
  (NOW, 'tiananmen', 'POINT(116.397 39.908)'),
  (NOW, 'airport',   'POINT(116.407 40.080)');

-- 查看 WKT 输出
SELECT name, ST_AsText(geom) AS wkt FROM geo_points;

业务场景示例

  1. 设备定位(点)
sql 复制代码
-- 设备位置入库
INSERT INTO geo_points VALUES
  (NOW, 'meter-001', 'POINT(121.48 31.23)');

-- 可视化取出
SELECT name, ST_AsText(geom) FROM geo_points WHERE name='meter-001';
  1. 巡检/线路(线串)
sql 复制代码
CREATE TABLE patrol_paths (
  ts TIMESTAMP,
  path_name VARCHAR(64),
  geom GEOMETRY(128)
);

INSERT INTO patrol_paths VALUES
  (NOW, 'line-1', 'LINESTRING(121.48 31.23,121.50 31.25,121.52 31.27)');

SELECT path_name, ST_AsText(geom) FROM patrol_paths;
  1. 服务/供电覆盖区(多边形)
sql 复制代码
CREATE TABLE service_zones (
  ts TIMESTAMP,
  zone_name VARCHAR(64),
  geom GEOMETRY(128)
);

INSERT INTO service_zones VALUES
  (NOW, 'zone-a', 'POLYGON((0 0,4 0,4 3,0 3,0 0))');

-- 取出 WKT 复核
SELECT zone_name, ST_AsText(geom) FROM service_zones;

注意事项

  • 输入必须是合法 WKT;坐标用空格分隔,同一点的首尾需闭合(多边形)。
  • 建议插入后用 ST_AsText 复核。
  • GEOMETRY 以二进制存储,WKT 仅作输入/输出格式。
  • 不区分 SRID,默认按原始数值存储;若需坐标系管理,请在应用侧约定。

关于 TDengine

TDengine 专为物联网IoT平台、工业大数据平台设计。其中,TDengine TSDB 是一款高性能、分布式的时序数据库(Time Series Database),同时它还带有内建的缓存、流式计算、数据订阅等系统功能;TDengine IDMP 是一款AI原生工业数据管理平台,它通过树状层次结构建立数据目录,对数据进行标准化、情景化,并通过 AI 提供实时分析、可视化、事件管理与报警等功能。

相关推荐
小陈工2 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
科技小花6 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸6 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
2501_948114246 小时前
2026年大模型API聚合平台技术评测:企业级接入层的治理演进与星链4SAPI架构观察
大数据·人工智能·gpt·架构·claude
D4c-lovetrain6 小时前
linux个人心得22 (mysql)
数据库·mysql
黎阳之光6 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
UTP协同自动化测试6 小时前
物联网模组测试难点 |APP指令下发+UART 响应+GPIO 电平变化,如何一次性验证?
功能测试·嵌入式硬件·物联网·模块测试
阿里小阿希7 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神7 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员7 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全