• mysql数据恢复:.frm和.ibd,恢复表结构和数据


    mysql数据恢复:.frm和.ibd,恢复表结构和数据


    相关内容原文地址:

    CSDN:她说巷尾的樱花开了:mysql根据.frm和.ibd文件恢复表结构和数据
    博客园:丹江流:Mysql 通过frm&ibd 恢复数据


    通过这次恢复数据发现,docker真的是方便,如果使用mysql客户端恢复,关闭,启动服务一直。使用docker容器启动mysql,很好 调试。

    一、恢复表结构

    1. 通过navicat新建数据库,在新建的数据库中,随意创建一张表,但是这张表的名字要和你要恢复的.frm或者.ibd一致,在此我的.frm与.ibd文件为songlyric.frm与songlyric.ibd因此我的创建表语句为:
    create table songlyric(id int);
    
    1. 在执行上面的创建表语句之后,使用net stop mysql关闭数据库服务(我使用的是Docker容器发布的mysql服务,则通过docker stop imageId关闭mysql数据即可),然后用需要恢复的songlyric.frm覆盖这个新建的wangyi数据库的songlyric表的物理文件songlyric.frm,接着对配置文件(my.ini,采用docker容器启动mysql,需要将mysql的配置文件挂载出来。-v /conf:/etc/mysql/conf.d)设置innodb_force_recovery = 6,然后使用net start mysql(docker启动mysql docker start mysql)启动服务,接着使用:desc songlyric查看该表结构,会出现下面错误信息:
      在这里插入图片描述
    2. 针对这个问题,我们可以通过查看mysql的日志文件来解决,查看mysql安装目录下的data文件夹里面.err结尾的文件,你会发现出现下面所示的错误信息:[Warning] InnoDB: Table wangyi/songlyric contains 1 user defined columns in InnoDB, but 6 columns in MySQL.原来是因为,我们要恢复的表有6个字段,而我们在创建表的时候只创建了1个字段。

    解决方案:删除songlyric表重新创建一个包含6个字段的表,具体这6个字段是什么不用管的。具体执行过程为使用net stop mysql停掉服务,然后在配置文件my.ini中将innodb_force_recovery = 6注释掉(#或;均可),再net start mysql启动服务。接着在控制台先执行drop table songlyric;删除表,再执行创建表语句,我执行的是下面的创建表语句:create table songlyric(id int,id1 int,id2 int,id3 int,id4 int,id5 int);

    紧接着按照前面的方式,使用net stop mysql关闭数据库服务,然后用需要恢复的songlyric.frm覆盖这个新建的wangyi数据库的songlyric表的物理文件songlyric.frm,接着对配置文件(my.ini)设置innodb_force_recovery = 6,然后使用net start mysql启动服务,接着使用:desc songlyric查看该表结构,输出下面结果表示恢复表结构成功:

    在这里插入图片描述

    二、恢复表数据

    1. 恢复表数据需要首先将原先的.ibd文件与原先的.frm文件解除绑定,具体就是在控制台执行下面命令:
      alter table songlyric discard tablespace;
    2. 接着执行net stop mysql停掉服务,将需要恢复的songlyric.ibd文件覆盖这个新建的wangyi数据库的songlyric表的物理文件songlyric.ibd,执行net start mysql开启服务。
    3. 将复制过来的songlyric.ibd文件与songlyric.frm文件发生联系。具体执行下面命令:
      alter table songlyric import tablespace;
    4. 这时候通过navicat查看数据表,你会发现数据已经成功恢复。
  • 相关阅读:
    C#-黑客-数据库访问-字符串的攻击和防御
    C#-数据库访问技术 ado.net——创建 数据库连接类 与 数据库操作方法 以及简单的数据的添加、删除、修改、查看
    C#把datetime类型的日期转化成年月日或其他格式方法总结
    C#—类库、委托、is和as运算符、泛型集合
    C#-面向对象的三大特性——多态(虚方法与重写、抽象类、接口)
    C#-面向对象的三大特性——继承
    C#-面向对象——如何调用使用类 普通方法、静态方法的使用
    C#-面向对象的三大特性——封装(封装成员变量、封装成员方法)
    面向对象的封装、继承、多态
    如何在HTMl网页中插入百度地图
  • 原文地址:https://www.cnblogs.com/aixing/p/13327147.html
Copyright © 2020-2023  润新知