这篇文章主要介绍“Mysql怎么根据.frm和.idb文件恢复表结构”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MysqL怎么根据.frm和.idb文件恢复表结构”文章能帮助大家解决问题。
根据.frm和.idb文件恢复表结构
.frm和.idb文件是MysqL数据库使用InnoDB数据库引擎时产生的两个文件。
举例:
admin.frm
文件存储的是admin的表结构信息,例如id是int型,id是admin的主键等元数据信息。admin.idb
文件存储的是admin表中的记录信息。例如admin表中(1,张三)一条记录信息。
如何根据.frm和.idb文件恢复表结构呢
第一步:下载安装MysqL 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语句
第三步:使用.idb文件恢复表中的记录
首先,将刚才创建的表的表空间卸载(删除.idb文件),执行完下面的这条命令之后将会自动删除该表的.idb文件。
在MysqL中执行
alter table 表名 discard tablespace;
然后,将需要恢复的.idb文件拷贝到刚才创建的数据表的 表名.frm文件所在的文件夹中(一般是在数据安装路径\data\数据库名 文件夹,在这个文件中可以看创建的表的.frm文件就对了)。
最后,使用下面的命令将复制的.idb文件导入到创建的表中。
在MysqL中执行
alter table 表名 import tablespace;
关于“MysqL怎么根据.frm和.idb文件恢复表结构”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程之家行业资讯频道,小编每天都会为大家更新不同的知识点。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。