mysql ibd是啥文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql ibd是啥文件相关的知识,希望对你有一定的参考价值。

ibd是mysql数据文件、索引文件,无法直接读取。 frm是表结构文件,可以直接打开。 参考技术A

在 InnoDB 中,用户定义的表及其对应的索引数据存储在扩展名为 .ibd 的文件中。表空间有两种类型,常规(或共享)表空间和每表独立表空间。对于共享表空间,来自许多不同表及其对应索引的数据可以驻留在单个 .ibd 文件中。而对于每表独立表空间,单个表的数据及其索引位于一个 .ibd 文件中。
. IBD 文件这些文件通常位于数据目录中。让我们尝试创建一个表 test.t1。

    mysql>CREATE TABLE test.t1 (c INT) engine=InnoDB;

    $ cd <PATH_TO_DATA_DIR>/test

    $ ls

    t1.ibd

上面是独立表空间文件,即与表 t1 相关的表和索引数据将驻留在此文件中。

    Mysql ibd文件恢复指南

    背景

      mysql在使用的过程中,难免遇到数据库表误操作,基于此,作者亲力亲为,对mysql数据表ibd文件的恢复做以下详细的说明,对开发或者初级dba提供一定的指导作用,博客中如若存在相关问题,请指明,相互学习,共同进步。

    恢复说明

    1.   创建数据库(随意创建),create database yygk
    2.       创建数据表
           
           备注:row_format要和ibd文件的row_format一致,否则,会提示两者不一致。 当前row_format=dynamic
    3.       表的属性查看
            我们使用:show table status like \'t_dict\'\\G,查看表的属性,截图如下。
           
            备注:细心的我们发现,创建表时候的row_format和表属性的不一致,基于innodb是,要把row_format设置成dynamic时,需要修改mysql的全局配置,直接在myql命令中修改:set global innodb_file_format=Barracuda;
    4.     表错误信息查看
         
         从错误日志中我们发现:row_format设置失败了,按照第3表中的说明,在myql命令中修改:set global innodb_file_format=Barracuda;然后重新创建表。
    5.   说明
         我们在恢复表的时候,要保证row_format和ibd文件的一致,如果ibd文件是compact的话,需要建表的时候,设置成row_format=compact,在恢复的时候,自行解决,从第6步开始,重点说明如何去恢复。
    6.   恢复第一步:移除表空间
        alter table t_dict DISCARD TABLESPACE;
    7.   恢复第二步:将备份的ibd文件,放到mysql->data->创建的数据库名称->,将ibd拷贝到此目录下,如下图所示
       
    8. 恢复第三步:重新导入表空间
        alter table t_dict IMPORT TABLESPACE;
    9. 后记
        当执行到上一步完成后,我们发现数据库中的数据已经完全恢复过来了。赞。赞。赞  今后我对mysql进行下深入的学习,掌握dba的技能,应用于项目开发。完结!!!!
    10. 大注意
      数据表的结构一定要和恢复前的数据表结构一致,否则恢复失败,导致mysql进程重启,详细情况需要查看mysql的error日志进行分析,另外,mysql的CE工具提供了便捷的mysql参数配置修改功能

    以上是关于mysql ibd是啥文件的主要内容,如果未能解决你的问题,请参考以下文章

    mysql数据库frm文件和ibd文件可以删除吗

    MySQL 8.0 恢复孤立文件每表ibd文件

    mysql数据库被破坏,只剩下ibd文件时如何恢复

    如何从ibd文件中恢复数据

    如何从ibd文件中恢复数据

    MYSQL .ibd文件数据恢复