欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql如何通過(guò)ibd文件恢復(fù)數(shù)據(jù)

 更新時(shí)間:2023年08月26日 09:55:34   作者:Smile_微笑  
這篇文章主要介紹了Mysql如何通過(guò)ibd文件恢復(fù)數(shù)據(jù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Mysql ibd文件恢復(fù)問(wèn)題

恢復(fù)步驟

1、創(chuàng)建數(shù)據(jù)庫(kù)(隨意創(chuàng)建)

2、創(chuàng)建數(shù)據(jù)表(備注:表結(jié)構(gòu)要和要恢復(fù)的表結(jié)構(gòu)一致,row_format要和ibd文件的row_format一致,否則,會(huì)提示兩者不一致。 當(dāng)前row_format=dynamic)

3、表的屬性查看

我們使用:show table status like ‘matlab’\G,查看表的屬性

備注:創(chuàng)建表時(shí)候的row_format和表屬性的不一致,基于innodb是,要把row_format設(shè)置成dynamic時(shí),需要修改mysql的全局配置,直接在myql命令中修改:set global innodb_file_format=Barracuda;

4、表錯(cuò)誤信息查看 show warnings

5、說(shuō)明我們?cè)诨謴?fù)表的時(shí)候,要保證row_format和ibd文件的一致,如果ibd文件是compact的話(huà),需要建表的時(shí)候,設(shè)置成row_format=compact,在恢復(fù)的時(shí)候,自行解決,從第6步開(kāi)始,重點(diǎn)說(shuō)明如何去恢復(fù)。

6、恢復(fù)第一步:移除表空間

 **alter table matlab DISCARD TABLESPACE;**

7、恢復(fù)第二步:將備份的ibd文件,放到mysql->data->創(chuàng)建的數(shù)據(jù)庫(kù)名稱(chēng)->,將ibd拷貝到此目錄下,如下所示具體路徑查看

-- 使用sql查詢(xún)數(shù)據(jù)目錄
**show global variables like '%datadir%';**

8、恢復(fù)第三步:重新導(dǎo)入表空間

 **alter table matlab IMPORT TABLESPACE;**

9、當(dāng)執(zhí)行到上一步完成后,我們發(fā)現(xiàn)數(shù)據(jù)庫(kù)中的數(shù)據(jù)已經(jīng)完全恢復(fù)過(guò)來(lái)了

10、數(shù)據(jù)表的結(jié)構(gòu)一定要和恢復(fù)前的數(shù)據(jù)表結(jié)構(gòu)一致,否則恢復(fù)失敗,導(dǎo)致mysql進(jìn)程重啟,詳細(xì)情況需要查看mysql的error日志進(jìn)行分析,另外,mysql的CE工具提供了便捷的mysql參數(shù)配置修改功能

mysql基于idb文件恢復(fù)數(shù)據(jù)問(wèn)題 

適用于mysql8.0+,mysql5版本沒(méi)測(cè)試過(guò)

數(shù)據(jù)庫(kù)因?yàn)榇疟P(pán)損壞起不來(lái)了,好在data目錄下的idb文件還在,可以基于idb文件恢復(fù)數(shù)據(jù)

步驟:

  • 創(chuàng)建schem和表
  • 將新建表關(guān)聯(lián)
  • 復(fù)制idb文件
  • import表

注意執(zhí)行順序

創(chuàng)建shcema

需要找一個(gè)同版本的mysql數(shù)據(jù)庫(kù),創(chuàng)建一個(gè)空的schema

create database test;

然后創(chuàng)建一個(gè)相同結(jié)構(gòu)的表結(jié)構(gòu)

//測(cè)試環(huán)境數(shù)據(jù)庫(kù)損壞,我登錄開(kāi)發(fā)環(huán)境切換到對(duì)應(yīng)db下,查看對(duì)應(yīng)的表結(jié)構(gòu)
//如果有備份的庫(kù)也可以,導(dǎo)入一個(gè)schmea查看表結(jié)構(gòu)。或者從開(kāi)發(fā)人員那里索要表結(jié)構(gòu)
show create table dev;
//這里是我在開(kāi)發(fā)環(huán)境上看到的表結(jié)構(gòu)
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;
//粘貼上面的表結(jié)構(gòu),到新建的庫(kù)下執(zhí)行,注意切換到對(duì)應(yīng)的schema上

將新建表關(guān)聯(lián)

上面我們把表結(jié)構(gòu)創(chuàng)建好了,接下來(lái)需要將表關(guān)聯(lián)

ALTER TABLE your_table DISCARD TABLESPACE;

復(fù)制idb文件

首先,將 .ibd 文件復(fù)制到 MySQL 數(shù)據(jù)目錄中,例如 /var/lib/mysql/your_database/ 目錄。

請(qǐng)確保文件具有正確的權(quán)限,并且 MySQL 用戶(hù)可以訪(fǎng)問(wèn)該文件

import表

//執(zhí)行完后我們可以切換到對(duì)應(yīng)的表下面,可以看到數(shù)據(jù)了
ALTER TABLE your_table IMPORT TABLESPACE;

//如果是給開(kāi)發(fā)人員使用,記得授權(quán)

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Windows環(huán)境下的MYSQL5.7配置文件定位圖文分析

    Windows環(huán)境下的MYSQL5.7配置文件定位圖文分析

    本文通過(guò)圖文并茂的形式給大家介紹了Windows環(huán)境下的MYSQL5.7配置文件定位 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • MySQL系列之十五 MySQL常用配置和性能壓力測(cè)試

    MySQL系列之十五 MySQL常用配置和性能壓力測(cè)試

    今天給大家?guī)?lái)一篇教程關(guān)于MySQL常用配置和性能壓力測(cè)試的知識(shí),文中配置參數(shù)以32內(nèi)存的服務(wù)器為例,通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-07-07
  • 深入MYSQL中的COLLATE

    深入MYSQL中的COLLATE

    MYSQL COLLATE是用于指定字符集的排序規(guī)則的關(guān)鍵詞,它可以用于在查詢(xún)中對(duì)字符數(shù)據(jù)進(jìn)行排序和比較,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-08-08
  • MySql常用數(shù)據(jù)類(lèi)型與操作詳解

    MySql常用數(shù)據(jù)類(lèi)型與操作詳解

    MySQL 是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),在WEB應(yīng)用方面 MySQL 是最好的。本文將為大家詳細(xì)介紹一下MySQL的基礎(chǔ)操作,需要的可以參考一下
    2022-07-07
  • MySQL DELETE語(yǔ)法使用詳細(xì)解析

    MySQL DELETE語(yǔ)法使用詳細(xì)解析

    此文章主要講述的是MySQL DELETE語(yǔ)法的詳細(xì)解析,以及一些在實(shí)際操作中值得我們大家注意的相關(guān)事項(xiàng)的描述,以下就是正文的主要內(nèi)容
    2013-03-03
  • MySQL for update鎖表還是鎖行校驗(yàn)(過(guò)程詳解)

    MySQL for update鎖表還是鎖行校驗(yàn)(過(guò)程詳解)

    在MySQL中,使用for update子句可以對(duì)查詢(xún)結(jié)果集進(jìn)行行級(jí)鎖定,以便在事務(wù)中對(duì)這些行進(jìn)行更新或者防止其他事務(wù)對(duì)這些行進(jìn)行修改,這篇文章主要介紹了MySQL for update鎖表還是鎖行校驗(yàn),需要的朋友可以參考下
    2024-02-02
  • Mysql優(yōu)化方法詳細(xì)介紹

    Mysql優(yōu)化方法詳細(xì)介紹

    MySQL的優(yōu)化指的是一個(gè)很大的系統(tǒng),面試的時(shí)候我之前是從sql的語(yǔ)句優(yōu)化方面去說(shuō)的,這種優(yōu)化也有作用,不過(guò)是從邏輯方面去優(yōu)化,下面這篇文章主要給大家介紹了關(guān)于MySQL查詢(xún)緩存優(yōu)化的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • MySQL?中的?SQL_MODE?設(shè)置方法ANSI_QUOTES?選項(xiàng)解析與應(yīng)用小結(jié)

    MySQL?中的?SQL_MODE?設(shè)置方法ANSI_QUOTES?選項(xiàng)解析與應(yīng)用小結(jié)

    sql_mode是?MySQL?中的一個(gè)系統(tǒng)變量,用于控制?SQL?語(yǔ)句的解析和執(zhí)行方式,它由多個(gè)選項(xiàng)組成,每個(gè)選項(xiàng)都可以獨(dú)立設(shè)置,以滿(mǎn)足不同的應(yīng)用場(chǎng)景需求,這篇文章主要介紹了MySQL?中的?SQL_MODE?設(shè)置:ANSI_QUOTES?選項(xiàng)解析與應(yīng)用
    2024-12-12
  • Mysql中DATEDIFF函數(shù)的基礎(chǔ)語(yǔ)法及練習(xí)案例

    Mysql中DATEDIFF函數(shù)的基礎(chǔ)語(yǔ)法及練習(xí)案例

    Datediff函數(shù),最大的作用就是計(jì)算日期差,能計(jì)算兩個(gè)格式相同的日期之間的差值,下面這篇文章主要給大家介紹了關(guān)于Mysql中DATEDIFF函數(shù)的基礎(chǔ)語(yǔ)法及練習(xí)案例?的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • MySQL中使用load data命令實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入的方法

    MySQL中使用load data命令實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入的方法

    MySQL支持load data命令的數(shù)據(jù)導(dǎo)入,該方式比直接的insert的效率要高,按照官方的說(shuō)法是要比insert語(yǔ)句快上20倍
    2013-10-10

最新評(píng)論