0

0

mysql版本升级中的备份与数据恢复流程

P粉602998670

P粉602998670

发布时间:2026-01-18 09:32:02

|

215人浏览过

|

来源于php中文网

原创

必须用mysqldump做逻辑备份而非直接拷贝文件,因跨大版本物理文件不兼容;恢复时需禁用外键与唯一性校验;8.0.16前须运行mysql_upgrade,之后自动升级;默认字符集变为utf8mb4、排序规则更严格,需逐库验证。

mysql版本升级中的备份与数据恢复流程

升级前必须用 mysqldump 做逻辑备份,而非直接拷贝文件

MySQL 版本跨大版本升级(如 5.7 → 8.0)时,datadir 下的物理文件结构、系统表格式、字符集默认行为都可能不兼容。直接复制 ibdata1.ibd 文件极大概率导致启动失败或数据损坏。必须使用 mysqldump 导出为 SQL 文本——它能自动适配源版本语法,并在恢复时由目标版本的 MySQL Server 解析执行。

实操建议:

  • --single-transaction --routines --triggers --events 参数保证一致性与完整性
  • 显式指定字符集:--default-character-set=utf8mb4,避免 5.7 默认 utf8(即 utf8mb3)在 8.0 中被拒绝
  • 排除 mysql 系统库:--ignore-table=mysql.user --ignore-table=mysql.db...,升级后应由 mysql_upgrade(8.0.16+ 已移除)或初始化流程重建权限表
  • 若库多、数据大,分库导出:mysqldump -u root -p --databases db1 db2 > backup.sql

mysql 客户端恢复时要禁用外键检查和唯一性校验

导入 dump 文件时,尤其是含大量关联表的场景,直接执行会因外键约束或唯一索引冲突中断。必须在恢复前临时关闭校验,否则常见错误如:ERROR 1215 (HY000): Cannot add foreign key constraintERROR 1062 (23000): Duplicate entry

实操建议:

  • 在 SQL 文件开头插入:
    SET FOREIGN_KEY_CHECKS=0;
    SET UNIQUE_CHECKS=0;
    SET AUTOCOMMIT=0;
  • 导入完成后手动执行:
    SET FOREIGN_KEY_CHECKS=1;
    SET UNIQUE_CHECKS=1;
    COMMIT;
  • 不要依赖 mysqldump --skip-extended-insert 来规避问题——它只影响 INSERT 格式,不解决约束冲突
  • 若用 source 命令导入,确保客户端连接时已设置 --init-command="SET NAMES utf8mb4",否则中文可能乱码

升级后首次启动必须运行 mysql_upgrade(仅限 8.0.16 之前)或检查系统表兼容性

MySQL 5.7 升级到 8.0.15 及更早版本时,mysql_upgrade 是强制步骤:它会检查并更新 mysql 系统库中的表结构(如 user 表字段变更)、修复权限视图、刷新帮助表。但自 8.0.16 起该工具已被移除,升级逻辑内建到服务启动流程中。

稻草人企业站1.0.7 GBK
稻草人企业站1.0.7 GBK

稻草人企业站程序,是一款简单开源的企业站程序,程序分为php+sqlite、php+mysql两个版本,程序采用php+smarty模板技术 修改模板方便,程序采用面对对象 模块开发.调用管理方便,程序可以开启伪静态功能,后台能编辑删除文件,后台能进行数据库管理、备份等操作,生成百度sitemap、Google sitemap功能,留言发邮件功能。 稻草人企业站程序 v1.0.7升级 1、增加安

下载

实操建议:

  • 对 8.0.15 及以下版本:停掉旧实例 → 替换二进制 → 启动新 mysqld → 运行 mysql_upgrade -u root -p
  • 对 8.0.16+ 版本:启动时若检测到旧系统表,会自动执行升级并写入日志,需确认 error log 中出现 Upgrading system tables.Finished upgrading system tables.
  • 无论哪个版本,升级后务必验证:SELECT VERSION();SELECT COUNT(*) FROM mysql.user;SHOW GRANTS FOR CURRENT_USER;
  • 注意:8.0 默认认证插件变为 caching_sha2_password,老客户端(如 MySQL 5.7 客户端或旧版 JDBC)可能连不上,需在用户创建时显式指定 IDENTIFIED WITH mysql_native_password

字符集与排序规则迁移最容易被忽略的三个细节

MySQL 8.0 将默认字符集从 latin1(5.7)改为 utf8mb4,默认排序规则从 latin1_swedish_ci 改为 utf8mb4_0900_ai_ci。这不是简单配置变更,会影响索引长度、比较行为、JSON 字段解析等。

实操建议:

  • 检查所有表的 CREATE TABLE 语句,确认是否显式声明了 CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci;未声明的会继承库级设置,而库级设置又继承 server 级,容易层层覆盖出错
  • utf8mb4_0900_ai_ci 对大小写不敏感且忽略重音,但比旧排序规则更严格——例如 'a' = 'A' 仍为 true,但某些特殊字符组合的比较结果可能不同,业务有精确匹配逻辑的需回归测试
  • 若应用依赖 utf8mb4_unicode_ci(如 PHP 的 mb_strtolower() 行为),需在建表或连接时显式指定,不能依赖默认值
  • 升级后执行:SELECT DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME='your_db'; 逐库确认
实际升级最耗时的环节往往不是执行命令,而是验证每个业务查询在新版本下的执行计划是否变化、JSON 字段是否仍可被正确解析、触发器是否还按预期触发——这些没法靠一键脚本覆盖,得靠你盯着慢查询日志和应用日志看。

相关文章

数据恢复工具app
数据恢复工具app

手机里的数据丢失了怎么办?聊天记录不小心删掉了怎么办?不用担心,这里为大家提供了数据恢复工具app下载,安全正规,有需要的小伙伴保存下载,就轻松恢复数据啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2632

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1632

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1513

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1418

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

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

共48课时 | 1.8万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 797人学习

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

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