Mysql如何通过ibd文件恢复数据

 更新时间:2023年08月26日 09:55:34   作者:Smile_微笑  
这篇文章主要介绍了Mysql如何通过ibd文件恢复数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

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参数配置修改功能

mysql基于idb文件恢复数据问题 

适用于mysql8.0+,mysql5版本没测试过

数据库因为磁盘损坏起不来了,好在data目录下的idb文件还在,可以基于idb文件恢复数据

步骤:

  • 创建schem和表
  • 将新建表关联
  • 复制idb文件
  • import表

注意执行顺序

创建shcema

需要找一个同版本的mysql数据库,创建一个空的schema

create database test;

然后创建一个相同结构的表结构

//测试环境数据库损坏,我登录开发环境切换到对应db下,查看对应的表结构
//如果有备份的库也可以,导入一个schmea查看表结构。或者从开发人员那里索要表结构
show create table dev;
//这里是我在开发环境上看到的表结构
CREATE TABLE `match_rules` (
  `id` bigint NOT NULL AUTO_INCREMENT,
  `app_id` varchar(32) DEFAULT NULL,
  `rule_id` varchar(32) DEFAULT NULL,
  `rule_type` int DEFAULT NULL,
  `conditions` json DEFAULT NULL,
  `results` json DEFAULT NULL,
  `show_data` json DEFAULT NULL,
  `create_time` datetime DEFAULT NULL,
  `update_time` datetime DEFAULT NULL,
  `valid` int DEFAULT NULL,
  `version_number` int DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=149 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
//粘贴上面的表结构,到新建的库下执行,注意切换到对应的schema上

将新建表关联

上面我们把表结构创建好了,接下来需要将表关联

ALTER TABLE your_table DISCARD TABLESPACE;

复制idb文件

首先,将 .ibd 文件复制到 MySQL 数据目录中,例如 /var/lib/mysql/your_database/ 目录。

请确保文件具有正确的权限,并且 MySQL 用户可以访问该文件

import表

//执行完后我们可以切换到对应的表下面,可以看到数据了
ALTER TABLE your_table IMPORT TABLESPACE;

//如果是给开发人员使用,记得授权

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Windows环境下的MYSQL5.7配置文件定位图文分析

    Windows环境下的MYSQL5.7配置文件定位图文分析

    本文通过图文并茂的形式给大家介绍了Windows环境下的MYSQL5.7配置文件定位 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • MySQL系列之十五 MySQL常用配置和性能压力测试

    MySQL系列之十五 MySQL常用配置和性能压力测试

    今天给大家带来一篇教程关于MySQL常用配置和性能压力测试的知识,文中配置参数以32内存的服务器为例,通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2021-07-07
  • 深入MYSQL中的COLLATE

    深入MYSQL中的COLLATE

    MYSQL COLLATE是用于指定字符集的排序规则的关键词,它可以用于在查询中对字符数据进行排序和比较,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • MySql常用数据类型与操作详解

    MySql常用数据类型与操作详解

    MySQL 是最流行的关系型数据库管理系统,在WEB应用方面 MySQL 是最好的。本文将为大家详细介绍一下MySQL的基础操作,需要的可以参考一下
    2022-07-07
  • MySQL DELETE语法使用详细解析

    MySQL DELETE语法使用详细解析

    此文章主要讲述的是MySQL DELETE语法的详细解析,以及一些在实际操作中值得我们大家注意的相关事项的描述,以下就是正文的主要内容
    2013-03-03
  • MySQL for update锁表还是锁行校验(过程详解)

    MySQL for update锁表还是锁行校验(过程详解)

    在MySQL中,使用for update子句可以对查询结果集进行行级锁定,以便在事务中对这些行进行更新或者防止其他事务对这些行进行修改,这篇文章主要介绍了MySQL for update锁表还是锁行校验,需要的朋友可以参考下
    2024-02-02
  • Mysql优化方法详细介绍

    Mysql优化方法详细介绍

    MySQL的优化指的是一个很大的系统,面试的时候我之前是从sql的语句优化方面去说的,这种优化也有作用,不过是从逻辑方面去优化,下面这篇文章主要给大家介绍了关于MySQL查询缓存优化的相关资料,需要的朋友可以参考下
    2023-02-02
  • MySQL 中的 SQL_MODE 设置方法ANSI_QUOTES 选项解析与应用小结

    MySQL 中的 SQL_MODE 设置方法ANSI_QUOTES 选项解析与应用小结

    sql_mode是 MySQL 中的一个系统变量,用于控制 SQL 语句的解析和执行方式,它由多个选项组成,每个选项都可以独立设置,以满足不同的应用场景需求,这篇文章主要介绍了MySQL 中的 SQL_MODE 设置:ANSI_QUOTES 选项解析与应用
    2024-12-12
  • Mysql中DATEDIFF函数的基础语法及练习案例

    Mysql中DATEDIFF函数的基础语法及练习案例

    Datediff函数,最大的作用就是计算日期差,能计算两个格式相同的日期之间的差值,下面这篇文章主要给大家介绍了关于Mysql中DATEDIFF函数的基础语法及练习案例 的相关资料,需要的朋友可以参考下
    2022-09-09
  • MySQL中使用load data命令实现数据导入的方法

    MySQL中使用load data命令实现数据导入的方法

    MySQL支持load data命令的数据导入,该方式比直接的insert的效率要高,按照官方的说法是要比insert语句快上20倍
    2013-10-10

最新评论