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

mysql數(shù)據(jù)如何通過data文件恢復(fù)

 更新時(shí)間:2022年12月13日 09:28:26   作者:屁仙  
這篇文章主要介紹了mysql數(shù)據(jù)如何通過data文件恢復(fù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

mysql數(shù)據(jù)通過data文件恢復(fù)

mysql磁盤文件被損壞,無法啟動(dòng),能看到data文件,在沒有備份的話如何復(fù)原?

情景1:知道數(shù)據(jù)庫中的表結(jié)構(gòu)

1、先執(zhí)行表結(jié)構(gòu)語句

2、解除綁定

alter table `表1` ?discard ?tablespace;
alter table `表2` ?discard ?tablespace;
......

此時(shí)當(dāng)前數(shù)據(jù)庫下所有的.idb文件都會(huì)被刪除,也就是只剩下表結(jié)構(gòu),原表數(shù)據(jù)被刪除

3、導(dǎo)入 .idb文件現(xiàn)有數(shù)據(jù)庫

也就是添加表數(shù)據(jù),不過,目前還沒有綁定

alter table `表1` ?import ? tablespace;
alter table `表2` ?import ? tablespace;
......

mysql數(shù)據(jù)恢復(fù)方法個(gè)人總結(jié)

mysql具有binlog功能,可以記錄對(duì)表進(jìn)行過的操作、執(zhí)行過的sql語句;

以下主要是總結(jié)下binlog的開啟方法、使用方法等;

如果誤刪數(shù)據(jù)庫表中的某些數(shù)據(jù)、或者誤刪整個(gè)表、誤修改表結(jié)構(gòu)等,就可以使用這個(gè)方法進(jìn)行恢復(fù)。

步驟

1.如果想使用MySql數(shù)據(jù)恢復(fù)功能,首先需要修改Mysql配置文件,開啟binlog功能。(有些版本binlog默認(rèn)是不開啟的,因此需要手動(dòng)修改配置文件開啟)

(1)windows環(huán)境

配置文件名稱為my.ini,可以安裝軟件everything搜索這個(gè)文件。路徑樣例如下:

C:ProgramDataMySQLMySQL Server 5.7my.ini

(2)linux環(huán)境

配置文件名稱為my.cnf,可以使用find命令搜索文件所在位置:

sudo find / -name my.cnf

位置樣例如下:

/etc/my.cnf

2.找到配置文件后(my.ini/my.cnf),新增以下配置即可(當(dāng)然先看看配置文件是否已配置了這行,不要重復(fù)了):

log-bin=mysqlbinlog
binlog-format=ROW

或者也可以指定binlog的位置(下方是linux下的路徑):

log-bin=/data/mysql/log/mysqlbinlog
binlog-format=ROW

注意,指定binlog在某個(gè)文件夾下時(shí),必須自己創(chuàng)建文件夾,否則重啟mysql會(huì)報(bào)錯(cuò)。

3.配置完成后,重啟mysql。

4.現(xiàn)在,對(duì)mysql的數(shù)據(jù)庫、表、數(shù)據(jù)等操作、執(zhí)行增刪改sql,都會(huì)記錄到binlog中。(搜索mysqlbinlog就可以找到這個(gè)日志文件)

5.進(jìn)行測(cè)試,新建一個(gè)表binlog_test,列隨意,然后寫幾行數(shù)據(jù),然后清空表數(shù)據(jù)。(準(zhǔn)備使用binlog還原數(shù)據(jù))

6.查看binlog的命令如下:

mysql> show binlog events; ? #只查看第一個(gè)binlog文件的內(nèi)容
mysql> show binlog events in 'mysqlbinlog.000002';#查看指定binlog文件的內(nèi)容
mysql> show binary logs; ?#獲取binlog文件列表
mysql> show master status; #查看當(dāng)前正在寫入的binlog文件

7.首先看當(dāng)前使用的是哪個(gè)binlog:

show master status;

本人執(zhí)行后,發(fā)現(xiàn)當(dāng)前使用的binlog是:mysqlbinlog.000004

8.然后查看這個(gè)binlog的內(nèi)容:

show binlog events in 'mysqlbinlog.000004';

執(zhí)行后,可以從查詢結(jié)果的Info列中,找到剛才創(chuàng)建binlog_test表的sql(對(duì)應(yīng)的Event_type是Query);

可以看到剛才清空表數(shù)據(jù)的記錄行,Event_type是Delete_rows;

在上一些,可以看到創(chuàng)建表后、新增數(shù)據(jù)的Event_type是Write_rows;

9.分析這個(gè)binlog,我們的目標(biāo)是還原剛才被刪除的數(shù)據(jù),因此找到create table語句后的第一個(gè)Event_type是Query的行,它的Pos為460;

再找到Event_type是Delete_rows上面最接近的、Info中是COMMIT的行,它的Event_type是Xid,End_log_pos是1199。

(每一行的End_log_pos對(duì)應(yīng)下一行的Pos)

10.現(xiàn)在找到了一個(gè)范圍,從460到1199之間的執(zhí)行日志,就是給表binlog_test增加數(shù)據(jù)的日志,因此只要重復(fù)執(zhí)行這之間的操作,就可以還原數(shù)據(jù)了。

11-1.windows下,找到mysqlbinlog.exe的位置;

linux下,找到mysqlbinlog的位置(這個(gè)是mysql的bin目錄下的一個(gè)可執(zhí)行文件);

然后執(zhí)行以下命令,即可還原數(shù)據(jù):

mysqlbinlog --no-defaults --start-position=460 --stop-position=1199 "C:ProgramDataMySQLMySQL Sever 5.7Datamysqlbinlog.000004" -d test | mysql -uroot -proot test

其中,指定了開始位置為460,結(jié)束位置為1199,命令執(zhí)行后就會(huì)讀取日志中指定范圍內(nèi)的命令并重新執(zhí)行。

其它命令的含義為:

  • "-d test"的意思是,指定數(shù)據(jù)庫為test(binlog_test表在test數(shù)據(jù)庫中)
  • "|"是管道符
  • "mysql -uroot -proot test"是mysql的賬號(hào)密碼、登陸目標(biāo)數(shù)據(jù)庫
  • "-uroot":賬號(hào)是root
  • "-proot":密碼是root
  • "test":數(shù)據(jù)庫是test 

11-2.也可以把binlog日志中,指定范圍內(nèi)的日志導(dǎo)出,然后自己執(zhí)行source命令還原數(shù)據(jù),如下:

mysqlbinlog "C:ProgramDataMySQLMySQL Sever 5.7Datamysqlbinlog.000004" -d test  --skip-gtids  --start-position=460 --stop-position=1199 > test.sql

執(zhí)行這個(gè)命令后,指定范圍內(nèi)的日志被導(dǎo)出到test.sql中;

然后登陸mysql,執(zhí)行命令:

mysql> use test;?
mysql> source test.sql;

這樣就可以還原數(shù)據(jù)了。

其它筆記

1.如果使用truncate刪除表的數(shù)據(jù),binlog中也會(huì)新增幾行記錄,記錄truncate操作,樣例如下:

mysqlbinlog.000004 | 3122 | Query | 1 | 3211 | use 'test'; TRUNCATE 'binlog_test'

如果想恢復(fù)數(shù)據(jù),就需要找到最開始插入數(shù)據(jù)的Pos、到truncate之前的End_log_pos,然后重新執(zhí)行這期間的命令。

2.增刪改操作會(huì)記錄到binlog中,慢查詢sql也可以記錄到慢查詢log中,不過也需要自己修改配置文件開啟慢查詢?nèi)罩尽?/p>

總結(jié)

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

相關(guān)文章

  • MySQL 重寫查詢語句的三種策略

    MySQL 重寫查詢語句的三種策略

    這篇文章主要介紹了MySQL 重寫查詢語句的三種策略,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-05-05
  • mysql binlog日志查詢不出語句問題及解決

    mysql binlog日志查詢不出語句問題及解決

    這篇文章主要介紹了mysql binlog日志查詢不出語句問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • mysql中between的用法及說明

    mysql中between的用法及說明

    這篇文章主要介紹了mysql中between的用法及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • MySQL常見故障與優(yōu)化方式

    MySQL常見故障與優(yōu)化方式

    這篇文章主要介紹了MySQL常見故障與優(yōu)化方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教<BR>
    2024-04-04
  • Mysql中substring_index函數(shù)實(shí)現(xiàn)字符分割一行變多行

    Mysql中substring_index函數(shù)實(shí)現(xiàn)字符分割一行變多行

    在MySQL中,字符串分割是一個(gè)常見的操作,本文主要介紹了Mysql中substring_index函數(shù)實(shí)現(xiàn)字符分割一行變多行,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • 一文教你學(xué)會(huì)定位線上MySQL鎖超時(shí)問題

    一文教你學(xué)會(huì)定位線上MySQL鎖超時(shí)問題

    這篇文章主要介紹了一文教你學(xué)會(huì)定位線上MySQL鎖超時(shí)問題,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • mysql 修改密碼和設(shè)置允許遠(yuǎn)程登錄

    mysql 修改密碼和設(shè)置允許遠(yuǎn)程登錄

    這篇文章主要介紹了mysql 修改密碼和設(shè)置允許遠(yuǎn)程登錄的相關(guān)資料,需要的朋友可以參考下
    2015-07-07
  • 詳解SQL注入--安全(二)

    詳解SQL注入--安全(二)

    這篇文章主要介紹了SQL注入安全,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 數(shù)據(jù)庫報(bào)錯(cuò):Unknown column 'xxx' in 'where clause'問題的解決過程

    數(shù)據(jù)庫報(bào)錯(cuò):Unknown column 'xxx' in 

    但凡寫過sql語句的人估計(jì)都曾經(jīng)碰到過類似于Unknown column ‘xxx’ in ‘where clause’的問題,這篇文章主要給大家介紹了關(guān)于數(shù)據(jù)庫報(bào)錯(cuò):Unknown column 'xxx' in 'where clause'問題的解決過程,需要的朋友可以參考下
    2023-03-03
  • mssql2008 自定義表類型實(shí)現(xiàn)(批量插入或者修改)

    mssql2008 自定義表類型實(shí)現(xiàn)(批量插入或者修改)

    在做大型網(wǎng)站或者系統(tǒng)的時(shí)候,經(jīng)常會(huì)遇到個(gè)問題就是批量插入或者修改數(shù)據(jù)庫;今天這邊不講SqlBulkCopy,只簡(jiǎn)單講sql自定義表類型,感興趣的朋友可以了解下哦,希望本文對(duì)你有所幫助
    2013-01-01

最新評(píng)論