阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Mysql通过ibd文件恢复数据的步骤详解

97次阅读
没有评论

共计 1048 个字符,预计需要花费 3 分钟才能阅读完成。

导读 mysql 在使用的过程中, 难免遇到数据库表误操作, 下面这篇文章主要给大家介绍了关于 Mysql 通过 ibd 文件恢复数据的详细步骤, 文中通过实例代码介绍的非常详细, 需要的朋友可以参考下
恢复步骤

1、创建数据库(随意创建)

2、创建数据表(备注:表结构要和要恢复的表结构一致,row_format 要和 ibd 文件的 row_format 一致,否则,会提示两者不一致。当前 row_format=dynamic)

3、表的属性查看

我们使用:show table status like‘matlab’\G,查看表的属性

备注:创建表时候的 row_format 和表属性的不一致,基于 innodb 是,要把 row_format 设置成 dynamic 时,需要修改 mysql 的全局配置,直接在 myql 命令中修改:set global innodb_file_format=Barracuda;

4、表错误信息查看 show warnings

5、说明

我们在恢复表的时候,要保证 row_format 和 ibd 文件的一致,如果 ibd 文件是 compact 的话,需要建表的时候,设置成 row_format=compact, 在恢复的时候,自行解决,从第 6 步开始,重点说明如何去恢复。

6、恢复第一步:移除表空间

**alter table matlab DISCARD TABLESPACE;**

7、恢复第二步:将备份的 ibd 文件,放到 mysql->data-> 创建的数据库名称 ->, 将 ibd 拷贝到此目录下,如下图所示
具体路径查看

-- 使用 sql 查询数据目录
**show global variables like '%datadir%';**

8、恢复第三步:重新导入表空间

**alter table matlab IMPORT TABLESPACE;**

9、当执行到上一步完成后,我们发现数据库中的数据已经完全恢复过来了

10、数据表的结构一定要和恢复前的数据表结构一致,否则恢复失败,导致 mysql 进程重启,详细情况需要查看 mysql 的 error 日志进行分析,另外,mysql 的 CE 工具提供了便捷的 mysql 参数配置修改功能

补充:Innodb 与 MyISAM 存储文件的区别
Innodb 存储文件分为:.frm,.idb
    .frm:存储表定义
    .ibd:存储数据和索引
MyISAM 存储文件分为:.frm,.myd,.myi
    .frm:存储表定义
    .myd:存储数据
    .myi:存储索引 

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-25发表,共计1048字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中