MySQL 通过.frm文件和.ibd文件实现InnoDB引擎的数据恢复
起因是这样的,公司的领导表示说服务器崩了,修理好之后,只剩下数据库目录下的物理文件(即.frm文件与.ibd文件)。然后,整了一份压缩包给我,叫我瞅一下能不能把数据恢复出来。我当场愣了一下,这都啥文件啊,以前天天整开发,也没见到这种玩意啊。虽然对这文件不是很熟悉,但是领导交给我了,我也不能推脱,好歹要努力一下看看。
环境准备:
1.本文使用的是Windows 笔记本*1 ( 系统可以是Windows、也可以是CentOS、Debian等等MySQL Utilities能兼容的都行)
2.MySQL 5.7+
一、什么是.frm文件
那么首先我要做的事情就是这.frm结尾的文件到底是什么东西?
我通过百度找到了MySQL官网,我点进去一看,第一段就是下面这句话。凭借着我不怎么样的英文,往下看了三行,发现了标红框的两句话。

得到的结论就是:
1..frm文件描述了表的格式,也就是说里面能获取到表的定义
2..frm文件与表格的名字相同
二、什么是.ibd文件
经过上面的猜测,很容易就可以联想到表结构都有了,那么这个.ibd文件可能就是存放数据、索引信息之类的了。
经过一番的百度,查阅到以下资料:
.ibd文件是使用InnoDB引擎的表产生的索引和数据文件。
(如果引擎使用的是MyISAM的话,会产生索引和数据分开存放的两个文件,.MYI(索引文件)和.MYD(数据文件))
三、获取frm文件的表结构信息
接下来,知道了有这么些文件,那么怎么把数据读取出来呢?
MySQL 提供了一款支持多个平台的工具软件,叫做MySQL Utilities。

这个工具包括克隆、复制、比较、差异、导出、导入、解析frm文件等功能。同时,这款软件支持多种系统使用,使用方法都是一致的。
(附下载地址:http://dev.mysql.com/downloads/utilities/)
通过命令:
mysqlfrm [.frm文件地址] --diagnostic
就可以查看frm文件包含的完整表结构了。

于是我手写了一个批处理脚本,把frm文件的表格结构都读取出来放在一个文本文件里,这样就获取到了所有的表结构。
CHCP 65001>nul
@echo off
for %%i in ([frm文件所在目录]\*.frm) do (
mysqlfrm %%i --diagnostic >> test.txt
)
pause
接着就是创建对应的数据库,把表结构的语句输入,执行一下SQL就可以了。
四、表结构有了,就可以开始恢复.ibd数据了
先把数据库里自带的数据文件脱离(脱离之后,表对应的.ibd文件会被删除)。
alter table aaa discard tablespace;
然后把原先的.ibd文件复制到数据库存放的数据目录。
不知道在哪的同学,可以执行以下语句查看数据目录位置:

这个目录里面是按照数据库分目录的:

找到我们自己的数据库,把.ibd文件复制进去。
到了这一步,就可以准备关联数据了。
执行以下命令关联数据:
alter table aaa import tablespace;
五、成功之后,就可以验证数据了。

在上述的过程中,我是批量操作的。
1.批量获取表结构
2.批量创建表
3.批量脱离表数据。
4.批量管理表数据。
最后,成功恢复数据。
感谢收看。
MySQL 通过.frm文件和.ibd文件实现InnoDB引擎的数据恢复的更多相关文章
- MySQL 利用frm文件和ibd文件恢复表结构和表数据
文章目录 frm文件和ibd文件简介 frm文件恢复表结构 ibd文件恢复表数据 通过脚本利用ibd文件恢复数据 通过shell脚本导出mysql所有库的所有表的表结构 frm文件和ibd文件简介 在 ...
- 重新学习MySQL数据库7:详解MyIsam与InnoDB引擎的锁实现
重新学习Mysql数据库7:详解MyIsam与InnoDB引擎的锁实现 说到锁机制之前,先来看看Mysql的存储引擎,毕竟不同的引擎的锁机制也随着不同. 三类常见引擎: MyIsam :不支持事务,不 ...
- 为什么 MySQL 回滚事务也会导致 ibd 文件增大?
一个简单的测试: start transaction; insert into tb1 values(3, repeat('a', 65000),'x',1); --commit; rollback; ...
- mysql InnoDB引擎 共享表空间和独立表空间(转载)
PS:innodb这种引擎,与MYISAM引擎的区别很大.特别是它的数据存储格式等.对于innodb的数据结构,首先要解决两个概念性的问题: 共享表空间以及独占表空间. 1.什么是共享表空间和独占表空 ...
- MySQL frm+ibd文件还原data的办法【数据恢复】
MySQL frm+ibd文件还原data的办法[数据恢复] 此方法只适合innodb_file_per_table = 1 当误删除ibdata 该怎么办? 如下步骤即可恢复: 1 ...
- 【MySQL】InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据
参考:http://my.oschina.net/sansom/blog/179116 参考:http://www.jb51.net/article/43282.htm 注意!此方法只适用于innod ...
- mysql通过frm+ibd文件还原data
此方法只适合innodb_file_per_table = 1 当误删除ibdata 该怎么办? 如下步骤即可恢复: 1.准备工作 1)准备一台纯洁的mysql环境[从启动到现在没有 ...
- MYSQL数据库根据data文件中的.frm和ibd文件恢复单表数据
数据库误操作,把表的字段删除了,关键是被删除的字段的数据很重要,现在想要恢复数据,下面说说是怎么操作的. 数据库只剩.frm和.ibd文件了,按照网上的做法分如下两步来进行:一.找回表结构,二.找回数 ...
- MySQL innodb引擎下根据.frm和.ibd文件恢复表结构和数据
记录通过.frm和.ibd文件恢复数据到本地 .frm文件:保存了每个表的元数据,包括表结构的定义等: .ibd文件:InnoDB引擎开启了独立表空间(my.ini中配置innodb_file_per ...
随机推荐
- JDBC_08_解决SQL注入问题 (登录和注册)
解决SQL注入问题 只要用户提供的信息不参与sql语句的编译过程,那么尽管用户输入的信息中含有sql关键字那么也不会起作用了 要想使用户提供信息不参与sql语句的编译过程,那么必须使用 java.sq ...
- 让我们一起建设 Vue DevUI 项目吧!🥳
DevUI Design 是从华为云 DevCloud 众多业务孵化出来的一套设计体系,DevUI 倡导沉浸.灵活.至简的设计价值观,提倡设计者为真实的需求服务,为多数人进行设计,拒绝哗众取宠.取悦眼 ...
- 【DB宝50】Oracle异构平台迁移之完全可传输导出导入(Full Transportable Export & Import)
目录 一.简介 1.1.使用场景 1.2.限制条件 二.完全可传输操作步骤 三.案例演示 3.1.环境 3.2.源库操作 3.2.1.将需要传输的用户表空间设置为RO状态 3.2.2.使用Data P ...
- SQL 查询的执行顺序
SELECT语句的完整语法如下 SELECT DISTINCT <select_list> FROM <left_table> <join_type> JOIN & ...
- Nginx 配置浏览Linux 系统目录并下载文件
准备工作: 安装编译工具及库文件: yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel 安装PCRE( ...
- Thinkphp5之laypage分页插件的实现
//一下是laypage所用到的 js <script type="text/javascript" src="__STATIC__/lib/laypage/1.2 ...
- 路由器逆向分析------sasquatch和squashfs-tools工具的安装和使用
本文博客地址:http://blog.csdn.net/qq1084283172/article/details/68942660 一.sasquatch工具的安装和使用 sasquatch工具支持对 ...
- <JVM下篇:性能监控与调优篇>05-分析GC日志
笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...
- [LeetCode]丑数 II&C++中priority_queue和unordered_set的使用
[LeetCode]丑数 II&C++中priority_queue和unordered_set的使用 考虑到现实因素,LeetCode每日一题不再每天都写题解了(甚至有可能掉题目?--)但对 ...
- C++ primer plus读书笔记——第13章 类继承
第13章 类继承 1. 如果购买厂商的C库,除非厂商提供库函数的源代码,否则您将无法根据自己的需求,对函数进行扩展或修改.但如果是类库,只要其提供了类方法的头文件和编译后的代码,仍可以使用库中的类派生 ...