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查看数据表,你会发现数据已经成功恢复。
  • 相关阅读:
    LeetCode 123. Best Time to Buy and Sell Stock III (stock problem)
    精帖转载(关于stock problem)
    LeetCode 122. Best Time to Buy and Sell Stock II (stock problem)
    LeetCode 121. Best Time to Buy and Sell Stock (stock problem)
    LeetCode 120. Triangle
    基于docker 搭建Elasticsearch5.6.4 分布式集群
    从零开始构建一个centos+jdk7+tomcat7的docker镜像文件
    Harbor实现容器镜像仓库的管理和运维
    docker中制作自己的JDK+tomcat镜像
    docker镜像制作---jdk7+tomcat7基础镜像
  • 原文地址:https://www.cnblogs.com/aixing/p/13327147.html
Copyright © 2011-2022 走看看