我正在尝试使用 SQLyog IDE 在 mySql 中执行复制表到不同的主机/数据库,并且在复制具有 2 个几何字段的表时遇到以下错误:
Cannot get geometry object from data you send to the GEOMETRY field
关于此错误还有其他几个 SO 问题,但大多数时候最终的答案是,这很可能是由于尝试插入空字符串而发生的(this 文章声称几何字段接受 NULL 值)。
在我的例子中,似乎与 NULL 或空字符串无关。
我能够找到因该错误而失败的第一个插入语句。这是它的样子:
(
45,
'2016-01-26 11:44:13',
'a',
'',
0,
0,
3,
100,
1,
1,
-- 1st geometry field
'\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0',
-- 2nd geometry field
'\0\0\0\0\0\0\0\0\0\0\0\0\0”¯oM¿”¯oM¿”¯oM¿”¯oM?”¯oM?”¯oM?”¯oM?”¯oM¿”¯oM¿”¯oM¿',
'Geodata',
- 1,
- 1,
1,
- 1
)
另一个插入失败的例子:
(
13853,
'2016-01-26 11:44:13',
'test move',
'',
3,
0,
1251,
0,
1,
0,
'\0\0\0\0\0\0\0kÛÚeA@Lˆv¡@@',
'\0\0\0\0\0\0\0\0\0\0\0\0\0¬Q^ÓdA@Ž„ì$Ø\n@@¬Q^ÓdA@Œ\0c@@)eW^eA@Œ\0c@@)eW^eA@Ž„ì$Ø\n@@¬Q^ÓdA@Ž„ì$Ø\n@@',
'test move',
- 1,
- 1,
2913,
- 1
)
如果我将这些与复制表中执行时没有错误的先前插入进行比较(我在目标表中看到它们),前两个是这样的:
(
31,
'2016-01-26 11:44:13',
'Route 1',
'',
2,
0,
3,
0,
1,
1,
'\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0',
'\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0',
'Geodata',
- 1,
- 1,
1,
- 1
),
(
32,
'2016-01-26 11:44:13',
'Route 2',
'',
2,
0,
3,
0,
1,
1,
'\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0',
'\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0',
'Geodata',
- 1,
- 1,
1,
- 1
)
我的眼睛在工作插入和非工作插入之间看到的唯一区别是后者包含我不知道是什么字符集的数据,而工作插入不是(它们的数据似乎是在几何数据类型术语中设置为 null/默认值)。
不工作的插入件有什么问题,您只要看一下就能知道吗?
P.S.:一位团队成员声称他通过更改 MySQL 服务器的 my.ini 文件解决了这个问题 - 通过将设置 max_allowed_packet 从 4M(默认)更改为 100M。
# The maximum size of one packet or any generated or intermediate string, or any parameter sent by the
# mysql_stmt_send_long_data() C API function.
max_allowed_packet=100M
我重新启动了我的机器,但这没有帮助,不断出现同样的错误。
最佳答案
以下内容对从 SQLYog IDE 执行Copy Table(s) To Different Host/Database 没有帮助,但显示了正确的 INSERT 语句的样子。
所以,回顾一下:
问题:如何在 mySql 中插入带有空间/几何字段的记录?
解决方案:如果您查询一个表是为了将其记录复制到另一个表中,您首先需要确保以正确的格式读取它们,一种可以被使用的格式mySql 函数 GeomFromText,用于从它的文本表示中创建空间/几何值。为了读取此类文本表示中的空间值,您需要使用函数 AsText。
这是一个例子:
然后,插入语句的值只需要将这些空间对象文本表示包装在对函数 GeomFromText 的调用中,例如(对于多边形)
GEOMFROMTEXT('POLYGON((-84.4920600543037 10.4982373909963,-84.4920600543037 10.4984201128037,-84.4918773324963 10.4984201128037,-84.4918773324963 10.4982373909963,-84.4920600543037 10.4982373909963))')
所以现在将一个包含空间字段的表转储到另一个表中是一件简单的事情,可以通过 SQL 或一个简单的应用程序来完成(我所做的)。
关于mysql - SQLyog Copy Table with geometry field failed with Cannot get geometry object from data you send to the GEOMETRY 字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40759920/