首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用Shell恢复MySQL .frm和.ibd文件

这是学习笔记的第 1901篇文章 MySQL里面对于表的默认的配置是每个表都有独立的文件.ibd和.frm文件对应,对于数据恢复来说,会提供很大的便利。...其中.frm文件存储了表结构定义信息,而.ibd文件存储了真正的数据。...如果某种特殊情况下,你只有.frm文件和.ibd文件,能不能单独恢复出来数据呢,答案是肯定的,当然这个过程不是一个命令搞定,而是需要一些方法和技巧。...比如.frm文件,我们拿到这个二进制文件的时候,其实我们也不知道里面到底有多少字段,怎么把DDL结构解析出来呢,这是第一个问题,而这个问题解决了之后,后续的问题其实就迎刃而解,我们可以完全使用迁移表空间的方式来处理...所以在恢复.frm和.ibd文件的时候,难点在于如何解析得到建表的DDL语句。 在这里我们要做个小把戏,需要预创建一个同名的表,然后通过交换frm文件来变相得到DDL语句。

2.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    宝塔面板用frm和ibd文件恢复Mysql数据

    这里顺便介绍一下.frm文件与.ibd文件与.ibdata文件 .frm:与表相关的元数据信息都存放在.frm文件中,主要是表结构的定义信息,不论什么存储引擎,每一个表都会有一个以表名命名的.frm文件...,但是打不开,打开直接报错, 教程开始 Mysql 5.6或者5.7,我这里用的是5.7。...服务 net stop mysql 或者点击计算机--管理--服务--找到Mysql 然后关闭 3 复制备份的.frm覆盖新建的表.frm 4 开启mysql服务 net start mysql 5....在mysql安装目录data文件夹下用文本编辑器打开.err文件 找到错误日志 然后删除当前表 新建4个字段的同名表,这里建议大家用可视设计mysql的软件来设置,比如Navicat,这样的话就可以更方便...服务 net stop mysql 然后再复制备份的.frm覆盖新建的表.frm 修改配置文件my.ini在[mysqld]下添加/修改innodb_force_recovery=6,一般这一段是没有的

    2.6K40

    MySQL:8.0全新的字典缓存(代替5.7 frm文件

    ---- 一、综述 在MySQL8.0中我们没有了frm文件,取而代之的是全新的字段缓存的设计和多个持久化的字典表,这部分不仅为原子性DDL提供了基础,而且减少打开物理frm文件的开销。...字典元素,命中率高,最大可缓存max connections个数的表字典信息) 持久化的表 而Dictionary_client和Shared_dictionary_cache和持久化的表就代替了原先的frm...文件。...这里需要注意的是open_table_def函数,在5.7基于是frm文件构建,而到了8.0就是我们提到的这里的字典元素了。...information_schema里面表的定义我们也能够发现,其中大部分为视图,其来源就是这些内部表,比如information_schema.tables这个视图,如下: 而在5.7中则是memory的表如下: 十一、打开

    2K20

    MySQL备份文件.ibd、.frm、.MYD、.MYI的恢复教程

    根据网友的截图得知是他在恢复数据文件 .frm 时,报出的异常。error: 1146: Table ‘xxx’ doesn’t exist ?...MySQL 数据库是具有持久化能力的。也就是说它的所有数据,其实最终都是存储在文件中的。如果你用的是 MyIsAM,则一张表数据文件有 3 个。 ?...如果是 InnoDB,则一张表有 2 个数据文件。 ? 且这些文件,一般在你安装 MySQL 目录中的 Data 目录中。 ?...然后,我们将 test_2019.ibd 和 test_2019.frm 两个文件复制到本地的其他目录。 要恢复 test_2019 这张表,我们先要用 SQL 创建出这种表。 ?...表创建出来之后,我们就可以到 /usr/local/var/mysql/test/ 替换 test_2019.ibd 和 test_2019.frm 两个文件了。 接着重启 MySQL 服务即可了。

    2.9K20

    从 Anemometer BUG 到 FRM 文件的恢复

    题目是Anemometer, 估计大部分不是MYSQLER的不大清楚这是个什么东西,其实这是几年前通过WEB界面查询MYSQL 慢查询的一个方法,安装上,通过一些脚本,就可以让每个MYSQL的服务器的慢查询显示出来...按下锅盖,起了瓢,最近MYSQL 的测试服务器,因为整改,原来的设置, 所有的文件都没有per file ,而是都在一个ibd 文件,整改后就出了问题,数据读不出来了,测试的数据倒是不重要,但是表结构对于测试时重要的...,开发人员希望能恢复MYSQL 的表结构,根据原来的经验,直接的选择就是 mysql-utilties 工具集合里面的 frm文件修复,本来想的很简单,现实很骨感,服务器上的PYTHON 版本 3.6,...搞到最后,连YUM 都不OK 了,(因为YUM 使用PYTHON),所以最后的结果是从新找了太干净的机器,按照老的方法把 mysql-utitiles 装上,然后恢复FRM 文件,本来还在担心这个工具集已经走到生命的终点...后来一想,MYSQL 8.0 就没有 FRM 文件了,这个功能就不需要在担心了。

    69520

    利用frm文件和ibd文件恢复表数据

    // 利用frm文件和ibd文件恢复表数据 // frm文件和ibd文件简介 在MySQL中,如果我们使用了默认的存储引擎innodb创建一张表,那么在文件夹下面就会出现表名.frm和表名.ibd...,而frm文件是innodb的表结构文件,mysiam存储引擎的表中,frm是表结构,MYI文件是索引文件,而MYD文件是数据文件,从这里也可以看出,innodb存储引擎的索引和数据是在一起的,而Myisam...需要注意的是,这个frm文件和ibd文件都是不能直接打开的。...我们可以使用frm文件盒ibd文件来对数据进行恢复。下面我们分析分析这个过程。 ? frm文件恢复表结构 当然,表结构需要使用frm文件来恢复。...总结一下利用frm文件恢复表结构的步骤: 1、首先创建一个同名的表,然后启动实例 2、使用备份的frm文件替代生成的frm文件,重启实例 3、查看错误日志,从错误日志中获取到备份的frm文件中的字段数量

    7.6K20

    恢复mysql数据结构(.frm)和数据(.ibd)

    简介: 1.后缀名为.frm文件:这个文件主要是用来描述数据表结构和字段长度灯信息 2.后缀名为.ibd的文件:这个文件主要储存的是采用独立表储存模式时储存数据库的数据信息和索引信息; 3...; 5.ibdata1文件:主要作用也是储存数据信息和索引信息 解决: 数据库的存储引擎 1:如储存引擎采用的是MyISAM,则生成的数据文件为表名.frm、表名.MYD、表名的MYI;...2:而储存引擎如果是innoDB,并且采用独立储存的模式,生成的文件是表名.frm、表名.ibd; 3:如果采用共存储模式的,数据信息和索引信息都存储在ibdata1中; 本地恢复 1,服务器...mysql的数据库(路径:/usr/local/mysql/var/mysql)(包含.frm,.ibd等)拷贝到本地的data下面。...2,打开本地mysql打开表可能会报1033。检查本地mysql版本和服务器mysql版本。 3,打开表—-报后缀名是ibd的文件报了表不存在。将ibdata1文件考到本地。

    1.4K20

    打开DEX文件

    APP解析 方法一(电脑端): .apk文件改为.zip文件 解压。...下载dex2jar软件 解压下载的文件 将 APK解压出来的文件夹下的 classes.dex 文件复制到 解压下的dex2jar文件下....在dex2jar文件夹目录处输入cmd 复制“d2j-dex2jar.bat classes.dex” 右键粘贴 会生成一个.jar文件 下载jd-gui软件 解压后打开软件 拖入.jar文件...手机端下载MT管理器app 左上角三条杠——-安装包提取——-定位 然后点击安装包——查看—–classes.dex———dex++编辑器打开 http://q2.qlogo.cn/headimg_dl...dst_uin=1377351008&spec=100 方法二(手机端): 手机APP–MT管理器 MT管理器可以直接打开 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    6.4K20

    打开 plist 文件

    对于使用苹果的进阶或资深玩家来说,有时候要编辑plist文件,比如要弄两个qq,要修改info.plist下的sku,而要是没有工具,就不能随意查看和编辑plist文件了。...下面介绍一下怎么查看和编辑plist文件。 1.首先,打开同步助手,然后连接手机(或者iPad),点击更多功能。 2.或者点文件,也可以进入U盘,进行文件存放。...5.双击打开plist文件,就可以进行编辑了,编辑完毕之后,记得要点保存,才修改有效。 6.为了更方便,将这个编辑器分离出来,独立使用。...需要注意的是,appuploader 工具并不会自动备份原文件,因此在上传文件前一定要记得备份文件。...此外,appuploader 工具只能上传 plist 文件,不能上传其他类型的文件,如 json、xml 等。

    3K30

    python打开文件

    打开文件 open函数用来打开文件,语法如下: open(name[, mode[,buffering]]) open函数使用一个文件名作为唯一的强制参数,然后返回一个文件对象。...假设我要打开我硬盘(I:/python/test.txt) 文件,可以用下面方法: >>> f = open(r'i:\python\test.txt') open函数中模式参数的常用值 image.png...基本文件方法 打开文件是第一步,下面就需要对文件进行读或写,可以write 和 read方法进行读或写。...关闭文件   应该牢记使用close方法关闭文件。...尽管一个文件对象在退出程序后会自动关闭,但关闭文件是没什么害处的,可以避免在某些操作系统或设置中进行无用的修改,这样做也会避免用完系统中打开文件的配额。

    3.3K30

    vim打开多个文件、同时显示多个文件、在文件之间切换 打开多个文件

    打开多个文件: 1.vim还没有启动的时候: 在终端里输入 vim file1 file2 ... filen便可以打开所有想要打开文件 2.vim已经启动 输入 :open file...可以再打开一个文件,并且此时vim里会显示出file文件的内容。...打开文档,此方式可以在编辑一个文档的同时打开另外一个文档 同时显示多个文件: :split 简写 :sp :vsplit 简写 :vsp # 显示缓存 :ls 在文件之间切换:...1.文件间切换 Ctrl+6—下一个文件 :bn—下一个文件 :bp—上一个文件 对于用(v)split在多个窗格中打开文件,这种方法只会在当前窗格中切换不同的文件。...(file) 多文件切换 通过vim打开多个文件(可以通过ctags或者cscope) ":ls"查看当前打开的buffer(文件) ":b num"切换文件(其中num为buffer list中的编号

    15.1K30

    python自学——文件打开

    #文件打开 新建一个文件new file.txt #方法一:f=open("yesterday","r",encoding="utf-8") # #首先给文件内存变量赋予一个变量F, 通常使用F作为变量名称...使用open函数来打开已有文件 #方法二:现在系统默认字符编码为utf-8 open("yesterday",encoding="utf-8").read() 有待更新,等我学习了字符编码在回来改...open("yesterday",encoding="utf-8").read() #f=open("文件name","定义模式”,encoding="utf-8") #定义模式有 """ "a" 追加...如果源文件中含有内容,会将文件中的内容删除.so 这种方法慎重使用----- #追加 append """ f=open("yesterday","a",encoding="utf-8") date=f.write...("\nnihao ")#注意好多人会将write写成append,记住aappend是定义模式,而此处的write是对文件内容定义 print(date) 打印date是不会显示文件全部内容的因为append

    1.9K20
    领券