温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2023-03-09 10:13:58 来源:亿速云 阅读:199 作者:iii 栏目:MySQL数据库

这篇文章主要介绍“Mysql怎么根据.frm和.idb文件恢复表结构”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Mysql怎么根据.frm和.idb文件恢复表结构”文章能帮助大家解决问题。

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

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

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

    • ~表名.idb文件存储的相关表中的数据记录。

    举例:

    • admin.frm文件存储的是admin的表结构信息,例如id是int型,id是admin的主键等元数据信息。

    • admin.idb文件存储的是admin表中的记录信息。例如admin表中(1,张三)一条记录信息。

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

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

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

    如果安装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/数据库名文件夹中。

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

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

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

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

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

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

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

    在Mysql中执行

    alter table 表名 discard tablespace;

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

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

    在Mysql中执行

    alter table 表名 import tablespace;

    关于“Mysql怎么根据.frm和.idb文件恢复表结构”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI