背景
MySQL在5.7版本中提供了Generated Column的功能,它可以通过函数计算获得新的一列数据,我们可以通过在虚拟列加索引的方式提高查询效率、分区表可使用虚拟列进行分区等。
问题现象
在使用低版本mysqldump命令做有虚拟列表的导入导出操作时,报错:
ERROR 3105 (HY000) at line 38: The value specified for generated column 'col1' in table 'tb_01' is not allowed.
复制
原因分析
mysqldump版本低于5.7.9的话,会误导出虚拟列数据,但是虚拟列是不允许被插入的,因此产生以上报错。
Changes in MySQL 5.7.9:mysqldump used incorrect syntax for generated column definitions. (Bug #20769542)
复制
解决方案
使用5.7.9以上版本的mysqldump工具导出含Generated Column的表的数据。
案例复现
1、测试表和数据
CREATE TABLE triangle (
sidea double DEFAULT NULL,
sideb double DEFAULT NULL,
sidec double GENERATED ALWAYS AS (sqrt(((sidea * sidea) + (sideb * sideb)))) VIRTUAL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into triangle(sidea,sideb)values(1,1),(3,4),(6,8);
复制
2、分别使用不同版本的mysqldump导出数据
- 使用低版本mysqldump导出数据示例
LOCK TABLES `triangle` WRITE;
/*!40000 ALTER TABLE `triangle` DISABLE KEYS */;
INSERT INTO `triangle` VALUES (1,2,2.23606797749979),(3,4,5),(2,9,9.219544457292887);
/*!40000 ALTER TABLE `triangle` ENABLE KEYS */;
UNLOCK TABLES;
复制
- 使用高版本mysqldump导出数据示例
LOCK TABLES `triangle` WRITE; /*!40000 ALTER TABLE `triangle` DISABLE KEYS */; INSERT INTO `triangle` (`sidea`, `sideb`) VALUES (1,2),(3,4),(2,9); /*!40000 ALTER TABLE `triangle` ENABLE KEYS */; UNLOCK TABLES;
复制
总结建议
建议mysqldump与MySQL Server版本对齐,避免使用较低版本导致类似Generated Column的新特性带来的兼容性问题。
最后修改时间:2021-08-12 14:32:34
文章转载自小小亮,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
2942次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
849次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
491次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
429次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
372次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
286次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
276次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
266次阅读
2025-05-06 14:40:00
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
248次阅读
2025-04-30 12:17:54
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
230次阅读
2025-04-28 11:01:25