Mysql中如何根据.frm和.idb文件恢复表结构
2021/12/15 2:17:27
本文主要是介绍Mysql中如何根据.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
;
按照上面的就可以恢复表结构和数据了,完美收工喽!
小白初入Mysql工作,请多多指教!
这篇关于Mysql中如何根据.frm和.idb文件恢复表结构的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-25MySQL报错Duplicate entry '0' for key 'PRIMARY'
- 2024-05-29阿里 Canal 实时同步 MySQL 增量数据至 ClickHouse 数据库
- 2024-05-24在Linux下管理MySQL的大小写敏感性
- 2024-04-26MySQL查出时间比实际晚8小时的解决方案
- 2024-04-01JPA不识别MySQL的枚举类型
- 2024-03-30mysql数据库表卡死解决方法
- 2024-03-15MySQL多数据源笔记5-ShardingJDBC实战
- 2024-03-11natural join mysql
- 2024-03-11关于VS2017,VS2015 中利用 EF使用Mysql 不显示数据源问题解决方案
- 2024-02-26mysql 阿里云xb后缀备份文件恢复-icode9专业技术文章分享