0

0

mysql版本迁移中的分区表与存储引擎兼容性

P粉602998670

P粉602998670

发布时间:2026-01-09 01:59:24

|

640人浏览过

|

来源于php中文网

原创

MySQL 5.7 升级到 8.0 后 PARTITION BY RANGE 报错主因是 8.0 强制要求 innodb_file_per_table=ON 且仅支持 InnoDB 分区表;8.0.29+ 严格校验 LIST 分区 NULL 处理;ARCHIVE 分区表在 8.0 被彻底移除;8.0.33+ 限制 KEY 子分区列必须属于主分区键。

mysql版本迁移中的分区表与存储引擎兼容性

MySQL 5.7 升级到 8.0 后 PARTITION BY RANGE 报错:”ERROR 1064 (42000)“

这不是语法错误,而是 MySQL 8.0 默认禁用了 innodb_file_per_table=OFF 场景下的分区表创建(尤其当原表使用 MyISAM 或旧式共享表空间时)。8.0 要求所有分区表必须基于 InnoDB,且每个分区需独立物理文件 —— 这直接依赖 innodb_file_per_table=ON

实操建议:

  • 升级前检查:
    SELECT @@innodb_file_per_table, @@default_storage_engine;
  • 若为 0,需先在 5.7 环境执行 SET GLOBAL innodb_file_per_table = ON;,再对每个分区表执行 ALTER TABLE tbl_name ENGINE=InnoDB; 触发文件拆分
  • 禁止在 8.0 初始化实例后,用 mysqldump --compatible=mysql40 导入含分区定义的 SQL —— 它会抹掉 PARTITION 子句但不报错,导致结构丢失

ALTER TABLE ... REORGANIZE PARTITION 在 8.0.29+ 中行为突变

MySQL 8.0.29 起,REORGANIZE PARTITIONLIST 分区的合法性校验更严格:不再允许合并包含 NULL 值的分区,也不接受新分区定义中遗漏原 VALUES IN 列表里的任意值。

常见错误信息:ERROR 1659 (HY000): Cannot move rows between partitions that have different definitions for handling NULL values

实操建议:

  • 升级前运行 SELECT PARTITION_NAME, PARTITION_DESCRIPTION FROM INFORMATION_SCHEMA.PARTITIONS WHERE TABLE_NAME = 'your_table'; 检查是否有 NULL 显式出现在 PARTITION_DESCRIPTION
  • 对含 NULLLIST 分区,改用 ALTER TABLE ... EXCHANGE PARTITION + 临时表方式重组,避免直接 REORGANIZE
  • 8.0.29+ 的 REORGANIZE 不再隐式复制数据,而是原子重写元数据 —— 若中途失败,分区状态不可逆,务必在低峰期操作并提前锁表

从 MySQL 5.6 迁移至 8.0 时 ARCHIVE 分区表直接失效

ARCHIVE 存储引擎自 MySQL 8.0 起被彻底移除,任何含 ENGINE=ARCHIVE 的分区定义在 8.0 实例启动时就会拒绝加载,错误日志显示:Unknown storage engine 'ARCHIVE',整个表无法访问。

YouWare
YouWare

社区型AI编程平台,支持一键部署和托管

下载

这不是兼容性警告,是硬性阻断。

实操建议:

  • 5.6/5.7 环境中,必须在迁移前将 ARCHIVE 分区表转为 InnoDB
    ALTER TABLE archived_log_table ENGINE=InnoDB ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=4;
  • 不要试图用 mysqldump --skip-create-options 绕过引擎声明 —— CREATE TABLE 语句仍含 ENGINE=ARCHIVE,导入 8.0 时照样失败
  • 若原表仅用于归档且读写极少,可考虑迁出数据后改用 8.0 的 DATA DIRECTORY + 只读表空间管理,而非保留分区逻辑

MySQL 8.0.33 后 subpartitionKEY 分区限制加剧

8.0.33 强制要求:子分区(SUBPARTITION)若使用 KEY 类型,其列必须全部来自主分区键(PARTITION BY 所用列),不能再引用额外列。此前版本虽不推荐但允许。

错误示例:

CREATE TABLE logs (
  id BIGINT,
  ts DATETIME,
  region VARCHAR(10)
) PARTITION BY RANGE (YEAR(ts))
SUBPARTITION BY KEY (region)  -- ❌ 8.0.33+ 拒绝:region 不在主分区键中

实操建议:

  • 升级前扫描所有含 SUBPARTITION BY KEY 的建表语句,确认子分区列是否严格属于主分区键字段集
  • 如需按 region 子分区,应改为 PARTITION BY RANGE COLUMNS(ts, region),或用 HASH 子分区配合计算列
  • 注意:8.0.33+ 的 KEY 子分区不再支持 ALGORITHM=INPLACE,变更必须重建全表

分区表迁移不是单纯 dump & restore,引擎限制、语法容忍度、元数据校验强度都在逐版本收紧。最容易被忽略的是那些“曾经能跑”的隐式行为 —— 比如 5.7 允许的 NULL 分区合并、ARCHIVE 表跨版本加载、子分区列自由引用,到了 8.0 某个补丁版就变成硬性报错。动手前务必查清目标小版本的具体变更日志,别只看大版本号。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1094

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

412

2024.04.29

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

1

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号