news 2026/5/12 7:59:32

MySQL【bug】- spatial key

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL【bug】- spatial key

【bug1】

MySQL建Spatial索引的前提条件是列定义NOT NULL,而当location列中有'GEOMETRYCOLLECTION EMPTY '的值时,这里'GEOMETRYCOLLECTION EMPTY'变相绕过了这个限制,会导致报错。

插入空集合GEOMETRYCOLLECTION EMPTY,空集合占一行空间,语义上“我知道这里该有几何,但当前没有数据”。

与 NULL 的区别

场景

存储值

ST_IsEmpty

ST_AsText

NULL

NULL

NULL

GEOMETRYCOLLECTION EMPTY

1

GEOMETRYCOLLECTION EMPTY

重建表也无法进行修复

CREATE TABLE `spatial_table` ( `id` int NOT NULL AUTO_INCREMENT, `name` varchar(255) DEFAULT NULL, `location` geometry NOT NULL SRID 4326, `number` varchar(20) NOT NULL DEFAULT '7425346', PRIMARY KEY (`id`), UNIQUE KEY `number` (`number`), SPATIAL KEY `location_index` (`location`) ); INSERT INTO spatial_table (id, name, location, number) VALUES (1, 'Place A', ST_GeomFromText('POINT(1 1)', 4326), '7425341'), (2, 'Place B', ST_GeomFromText('LINESTRING(1 1,2 2,3 3)', 4326), '7425342'), (3, 'Place C', ST_GeomFromText('POLYGON((0 0,10 0,10 10,0 10,0 0),(5 5,7 5,7 7,5 7,5 5))', 4326), '7425343'), (4, 'Place D', ST_GeomFromText('MULTIPOINT((0 0),(20 20),(60 60))', 4326), '7425344'), (5, 'Place E', ST_GeomFromText('GEOMETRYCOLLECTION(POINT(10 10),POINT(30 30),LINESTRING(15 15,20 20))', 4326), '7425345'), (6, 'Place F', ST_GeomFromText('GEOMETRYCOLLECTION(POINT(10 10),POINT(30 30),LINESTRING(15 15,20 20))', 4326), '7425348'), (7, 'Beijing', ST_GeomFromText('POINT(39.9042 116.4074)', 4326), '7425347'), (8, '<null>', ST_GeomFromText('GEOMETRYCOLLECTION EMPTY', 4326), '7425346'); SELECT id,name,st_astext(location),number From spatial_table;

解决方法:删除这些行并重建表

【bug2】

先对含SPATIAL KEY的表做过ALTER TABLE → R-tree根页指针错乱,后续UPDATE/DELETE走空间索引时找不到记录 → 报Record in index ... not found。在MySQL Server 5.7.498.0.418.4.49.2.0版本中修复。

官方文档:https://bugs.mysql.com/bug.php?id=93728

CREATE TABLE tab ( c1 INT NOT NULL PRIMARY KEY, c2 POINT NOT NULL SRID 4326, c3 LINESTRING NOT NULL SRID 4326, c4 POLYGON NOT NULL SRID 4326, c5 GEOMETRY NOT NULL SRID 4326, SPATIAL KEY idx2 (c2), SPATIAL KEY idx3 (c3), SPATIAL KEY idx4 (c4), SPATIAL KEY idx5 (c5) ) ENGINE = InnoDB; INSERT INTO tab(c1,c2,c3,c4,c5) VALUES (1, ST_GeomFromText('POINT(10 10)', 4326), ST_GeomFromText('LINESTRING(5 5,20 20,30 30)', 4326), ST_GeomFromText('POLYGON((30 30,40 40,50 50,30 50,30 40,30 30))', 4326), ST_GeomFromText('POLYGON((30 30,40 40,50 50,30 50,30 40,30 30))', 4326)); INSERT INTO tab(c1,c2,c3,c4,c5) VALUES (2, ST_GeomFromText('POINT(20 20)', 4326), ST_GeomFromText('LINESTRING(20 20,30 30,40 40)', 4326), ST_GeomFromText('POLYGON((40 50,40 70,50 100,70 100,80 80,70 50,40 50))', 4326), ST_GeomFromText('POLYGON((40 50,40 70,50 100,70 100,80 80,70 50,40 50))', 4326)); ALTER TABLE tab ADD COLUMN new_uniq_col INT NOT NULL AUTO_INCREMENT FIRST, ADD UNIQUE INDEX uniq_idx(new_uniq_col), DROP PRIMARY KEY; DELETE From tab;

解决方法:

  • 升级版本
  • 重建表再重新导入数据

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 4:22:30

SEO+SEM整合营销实战案例:某B2B企业如何实现流量翻倍

在竞争激烈的B2B市场&#xff0c;如何通过SEOSEM整合营销实现流量翻倍&#xff1f;本文以某企业实战案例&#xff0c;揭秘如何运用Google Ads精准投放、Facebook广告与LinkedIn营销协同&#xff0c;结合Google SEO优化与TikTok海外运营&#xff0c;打造高效获客矩阵。从策略制定…

作者头像 李华
网站建设 2026/5/8 11:10:23

OrCAD下载常见问题解析:快速理解核心要点

OrCAD下载避坑指南&#xff1a;从连接失败到授权激活的全链路实战解析 你是不是也曾在搜索引擎里输入“orcad下载”&#xff0c;结果跳出来的不是404页面&#xff0c;就是一堆失效链接和论坛求助帖&#xff1f;明明只是想装个电路设计软件&#xff0c;怎么感觉像在破解一道网络…

作者头像 李华
网站建设 2026/5/1 17:20:32

Packet Tracer中HTTP协议交互的通俗解释与动态演示

在Packet Tracer里“看见”HTTP&#xff1a;一次从点击到网页加载的深度旅程你有没有想过&#xff0c;当你在浏览器里输入一个网址&#xff0c;按下回车后&#xff0c;到底发生了什么&#xff1f;对大多数人来说&#xff0c;页面加载只是一个瞬间——快则几百毫秒&#xff0c;慢…

作者头像 李华
网站建设 2026/5/11 16:02:18

无源蜂鸣器PWM驱动原理:频率调制技术深度剖析

无源蜂鸣器如何“唱歌”&#xff1f;——用PWM玩转频率调制的硬核实战解析你有没有想过&#xff0c;一个几毛钱的无源蜂鸣器&#xff0c;是怎么“演奏”出《生日快乐》或者报警提示音的&#xff1f;它不像扬声器那样能播放音乐文件&#xff0c;也没有内置芯片来自动发声。但它却…

作者头像 李华
网站建设 2026/5/9 21:20:17

React Native 0.74.2 升级指南与错误修复

引言 最近,React Native 发布了0.74.2版本,带来了许多新特性和改进。然而,升级到这个版本后,许多开发者遇到了pod install运行时出现的错误。本文将详细介绍这些问题的原因以及如何解决这些问题。 问题背景 在升级到React Native 0.74.2后,运行pod install时,可能会遇…

作者头像 李华