zoukankan      html  css  js  c++  java
  • 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查看数据表,你会发现数据已经成功恢复。
  • 相关阅读:
    JS 数字时钟的代码(摘录,忘了是从哪了)
    数据写入DataTable C# 2005
    C# 进制转化问题测试下再说(网上的直接转化不好用)
    防sql 注入,就是将sql 的执行命令给排除
    今天研究了一下午网站窄屏/宽屏的切换实现
    解决VS2005下中文输入法全角半角混乱的补丁
    一些实用的站长查询工具
    UE(用户体验)无处不在,留心处处皆学问
    添加了方便聚合的链接
    该好好整理一下自己了
  • 原文地址:https://www.cnblogs.com/aixing/p/13327147.html
Copyright © 2011-2022 走看看