当前位置: 首页 > news >正文

Mysql8.0 gis支持

GIS数据类型
MySQL的GIS功能遵守OGC的OpenGIS Geometry Model,支持其定义的空间数据类型的一个子集,包括以下空间数据类型:

  • GEOMETRY:不可实例化的数据类型,但是可以作为一个列的类型,存储任何一种其他类型的数据
  • POINT:点
  • LINESTRING:线
  • POLYGON:多边形,由多条闭合的线构成的图形
  • MULTIPOINT:点集合
  • MULTILINESTRING:线集合
  • MULTIPOLYGON:多边形集合
  • GEOMCOLLECTION:空间对象集合
    其中GEOEMTRY、POINT、LINESTRING、POLYGON用于保存单个空间数据,并且GEOMETRY可以存储其它任意单个空间数据类型,即如果一个字段定义是GEOMETRY类型,那么该字段可以存储其它类型(不包括集合)的数据,而其它类型必须存储特定类型的数据

WKT
即文本格式,在用户操作GIS类型的数据时可以使用直观的文本进行插入或查询,MySQL支持OpenGIS定义的语法来写WKT数据,示例如下:

Point:POINT(15 20)
LineString:LINESTRING(0 0, 10 10, 20 25, 50 60)
Polygon :POLYGON((0 0,10 0,10 10,0 10,0 0),(5 5,7 5,7 7,5 7, 5 5))
MultiPoint:MULTIPOINT(0 0, 20 20, 60 60)
MultiLineString:MULTILINESTRING((10 10, 20 20), (15 15, 30 15))
MultiPolygon:MULTIPOLYGON(((0 0,10 0,10 10,0 10,0 0)),((5 5,7 5,7 7,5 7, 5 5)))
GeometryCollection:GEOMETRYCOLLECTION(POINT(1 -1), POINT(10 10), POINT(30 30), LINESTRING(15 15, 20 20))

在用户进行插入时可以使用ST_GeomFromText等函数来将WKT格式的GIS数据转换成内部格式进行插入,在进行查询时可以使用ST_AsText函数来将内部数据转换为更直观的WKT结果格式。

例子:

-- emergency_fire.test definition
CREATE TABLE `test` (`id` int NOT NULL AUTO_INCREMENT,`pnt` point DEFAULT NULL,`pgn` polygon DEFAULT NULL,`str` varchar(100) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=20 DEFAULT CHARSET=utf8mb3;
INSERT INTO emergency_fire.test
(id, pnt, pgn, str)
VALUES(2, ST_GeomFromText('POINT(15 20)'), ST_GeomFromText('POLYGON ((0 0, 10 0, 10 10, 0 10, 0 0))'), 'POLYGON((0 0, 10 0, 10 10, 0 10, 0 0))');
UPDATE emergency_fire.test
SET pgn=ST_GeomFromText(str);

GIS函数:
例子 判断多边形包含点:

SELECT id FROM emergency_fire.test 
where ST_Contains(pgn, st_geomfromtext('POINT(8 8)') )

https://blog.csdn.net/An1090239782/article/details/121263678

http://www.lryc.cn/news/63302.html

相关文章:

  • 汇编---Nasm
  • NDK OpenGL渲染画面效果
  • 常见的深度学习框架
  • 【设计模式】七大设计原则--------单一职责原则
  • MySQL-中间件mycat(一)
  • ARM寄存器组织
  • 记录一次webdav协议磁盘挂载经验总结
  • 安装Django
  • 【前端面经】JS-如何使用 JavaScript 来判断用户设备类型?
  • 压缩HTML引用字体
  • 大厂高频面试:底层的源码逻辑知多少?
  • 【学习笔记】CF607E Cross Sum
  • Python 一元线性回归模型预测实验完整版
  • GStreamer第一阶段的简单总结
  • 【网络进阶】服务器模型Reactor与Proactor
  • 使用div替代<frameset><frame>的问题以及解决办法
  • Verilog中的`define与`if的使用
  • 沃尔玛、亚马逊影响listing的转化率4大因素,测评补单自养号解析
  • 静态分析和动态分析
  • 代码随想录_贪心_leetcode 1005 134
  • 笔记:对多维torch进行任意维度的多“行”操作
  • 【VSCode】1、VSCode 如何连接服务器
  • AI工具:通过智能实现工作和学习效率的革命化
  • static 和构造方法
  • 【Linux 裸机篇(八)】I.MX6U EPIT 定时器中断、定时器按键消抖
  • Web安全 XSS靶场搭建(玩转整个XSS环境.)
  • 前端开发技术——DOM(上)
  • 银河麒麟v10服务器版安装OpenDDS
  • curl方式调用电商API接口示例 详细介绍
  • Duboo介绍与入门