Windows MySQL 数据库文件恢复记录

Windows MySQL 数据库文件恢复记录

前情

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

  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个小时,数据还原过程还经历了磁盘空间不足的情况,切记对数据库操作时能备份数据一定、一定、一定要备份数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值