Windows MySQL 数据库文件恢复记录

阅读: 评论:0

Windows MySQL 数据库文件恢复记录

Windows MySQL 数据库文件恢复记录

Windows MySQL 数据库文件恢复记录

  • 前情
    • 车祸现场恢复过程
      • 恢复模型
      • 模型恢复
      • 数据恢复

前情

windows环境下修改了MySQL的myf文件造成数据无法启动。

  1. 只复制了data下的对应数据库的文件夹
  2. 使用MySQL Installer卸载并删除对应的data文件夹
  3. 使用MySQL Installer安装
  4. 将数据库文件夹复制到data目录下(原以为重启数据库后会自动识别)
  5. 数据库无法识别

网上的教程都是针对复制了整个data文件的说明,假设使用docker将数据卷的内容备份了,迁移时重新指定数据卷就可以自动识别了,这个是正常的套路

车祸现场恢复过程

600万的数据无法恢复,单个库的大小接近2G

恢复模型

从开发环境或测试环境中将数据模型导出

模型恢复

在新建的环境中创建与删除前一模一样的数据库名称,使用导出数据模型恢复数据库结构

数据恢复

  1. 将原复制的数据库文件夹覆盖新实例创建的文件夹
  2. 重启数据库实例
  3. 原覆盖的目标表已无法查询,报异常如下:
    Error Code:1812. Tablespace is missing for table <table_name>
  4. 使用下面语句可解决:
	ALTER TABLE <table_name> IMPORT TABLESPACE;
  1. 索引丢失问题(开发环境没有索引),在恢复的大表中新建索引失败,几百万的数据如果没有索引一查询就是全表,多查几次就把实例的CPU搞趴了,特别是又有count的情况。
  2. 新建临时表,该临时表结构与原表一模一样,创建好索引
  3. 执行复制语句:
insert into A select * from B;

8.到此数据已恢复,增删改查正常

总共折腾了4个小时,数据还原过程还经历了磁盘空间不足的情况,切记对数据库操作时能备份数据一定、一定、一定要备份数据。

本文发布于:2024-01-31 18:07:17,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170669564030383.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:数据库文件   Windows   MySQL
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23