Mysql之如何根据.frm和.idb文件恢复表结构

 更新时间:2023年3月10日 16:34  点击:510 作者:☆会飞的阿猫☆

根据.frm和.idb文件恢复表结构

.frm和.idb文件是Mysql数据库使用InnoDB数据库引擎时产生的两个文件。

  • ~表名.frm文件存储的相关表的表结构、索引等元数据。
  • ~表名.idb文件存储的相关表中的数据记录。

举例:

  • admin.frm文件存储的是admin的表结构信息,例如id是int型,id是admin的主键等元数据信息。
  • admin.idb文件存储的是admin表中的记录信息。例如admin表中(1,张三)一条记录信息。

如何根据.frm和.idb文件恢复表结构呢

第一步:下载安装MYSQL Utilities工具

官方下载地址:https://downloads.mysql.com/archives/utilities/

如果安装64位工具出现报错时可以尝试换成32位的工具。(亲测有效)

第二步:使用.frm文件恢复表结构

首先,使用Win + R快捷键打开DOS窗口,使用CD切换到.frm文件所在路径。

例如:admin.frm文件在D:mysql-5.7.31-winx64/data/数据库名文件中。

则需要 CD /d mysql-5.7.31-winx64/data/数据库名文件夹中。

然后,使用mysqlfrm --diagnostic ./文件名.frm命令来导出建表的sql语句

使用建表sql语句在Mysql数据库中创建相应的表。

第三步:使用.idb文件恢复表中的记录

首先,将刚才创建的表的表空间卸载(删除.idb文件),执行完下面的这条命令之后将会自动删除该表的.idb文件。

在Mysql中执行

alter table 表名 discard tablespace;

然后,将需要恢复的.idb文件拷贝到刚才创建的数据表的 表名.frm文件所在的文件夹中(一般是在数据安装路径\data\数据库名 文件夹,在这个文件中可以看创建的表的.frm文件就对了)。

最后,使用下面的命令将复制的.idb文件导入到创建的表中。

在Mysql中执行

alter table 表名 import tablespace;

按照上面的就可以恢复表结构和数据了,完美收工喽!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持猪先飞。

原文出处:https://blog.csdn.net/qq_43537005/article/details/121942215

[!--infotagslink--]

相关文章

  • 华为手机怎么恢复已卸载的应用?华为手机恢复应用教程

    华为手机怎么恢复已卸载的应用?有时候我们在使用华为手机的时候,想知道卸载的应用怎么恢复,这篇文章主要介绍了华为手机恢复应用教程,需要的朋友可以参考下...2020-06-29
  • PostgreSQL 恢复误删数据的操作

    这篇文章主要介绍了PostgreSQL 恢复误删数据的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-18
  • C#中进程的挂起与恢复

    这篇文章主要介绍了C#中进程的挂起与恢复操作方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下...2020-06-25
  • MySQL 从全库备份中恢复指定的表和库示例

    这篇文章主要介绍了MySQL 从全库备份中恢复指定的表和库示例的相关资料,这里提供了相应的方法,来实现恢复指定的表和库数据,需要的朋友可以参考下...2016-12-02
  • MySQL数据库遭到攻击篡改(使用备份和binlog进行数据恢复)

    这篇文章主要介绍了MySQL数据库遭到攻击篡改(使用备份和binlog进行数据恢复),需要的朋友可以参考下...2016-04-26
  • MySQL备份恢复设计思路

    这篇文章主要介绍了MySQL备份恢复设计思路,帮助大家更好的维护数据库,感兴趣的朋友可以了解下...2020-10-15
  • delete误删数据使用SCN号恢复(推荐)

    这篇文章主要介绍了使用scn号恢复误删数据问题,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11
  • 三星s5820如何恢复出厂设置

    提示,恢复出厂前我们最好对数据进行一些备份哦,包括:联系人,短信,电话,视频,照片哦,恢复之后手机中的数据就丢失了。 具体方法 1.在待机模式下,点击【应用程序】。 2.点击...2016-09-20
  • pgsql 实现用户自定义表结构信息获取

    这篇文章主要介绍了pgsql 实现用户自定义表结构信息获取,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-04
  • MySQL5.7 mysqldump备份与恢复的实现

    这篇文章主要介绍了MySQL5.7 mysqldump备份与恢复的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-03
  • 分布式文档存储数据库之MongoDB备份与恢复的实践详解

    这篇文章主要介绍了分布式文档存储数据库之MongoDB备份与恢复,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-12-08
  • php mysql备份恢复分卷处理(数据库导入导出)

    分卷处理就是把握们要处理的数据分成一个个小文件进行处理了,下面我来给大家介绍一个php mysql备份恢复分卷处理类,实现mysql数据库分卷备份,选择表进行备份,实现单个sq...2016-11-25
  • mysql alter table命令修改表结构实例

    这篇文章主要介绍了mysql alter table命令修改表结构实例的相关资料,需要的朋友可以参考下...2016-10-20
  • 如何在SQL Server中恢复数据

    在SQL server 中恢复数据的几种办法: 1.自然就是 backup 的 恢复方法 backup 这种方法是最安全,最可靠的方法操作起来也很简单,只要在 sql server 的 enterprise manage...2016-11-25
  • MySQL系列之十二 备份与恢复

    这篇文章主要介绍了MySQL 数据备份与还原的相关知识,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下,希望可以帮到你们...2021-07-03
  • 如何恢复MYSQL的ROOT口令

    怎样恢复MYSQL的口令 如果你忘记了你的MYSQL的root口令的话,你可以通过下面的过程恢复。 1. 向mysqld server 发送kill命令关掉mysqld server(不是 kill -9),存放...2016-11-25
  • Linux利用lsof/extundelete工具恢复误删除的文件或目录

    这篇文章主要给大家介绍了关于Linux利用lsof/extundelete工具恢复误删除的文件或目录的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-08-24
  • 三星i9100恢复出厂设置详解教程

    恢复出厂设置前我们先要对手机中的电话,联系人,短信,照片,视频进行备份哦,否则恢复出厂设置之后手机中这些数据都会丢失的哦。 1、在我们手机中点击【菜单】-【设置】...2016-09-20
  • Postgresql备份和增量恢复方案

    这篇文章主要给大家介绍了关于Postgresql备份和增量恢复的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Postgresql具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-07-11
  • pycharm 实现调试窗口恢复

    这篇文章主要介绍了pycharm 实现调试窗口恢复的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-05