mysql怎么還原文件 mysql怎么還原數(shù)據(jù)庫(kù)

重裝系統(tǒng)后,mysql應(yīng)該怎么恢復(fù)過(guò)去

1、先在運(yùn)行中輸入services.msc,找到MysQL的服務(wù),將其停止;

創(chuàng)新互聯(lián)是一家專(zhuān)注于成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作與策劃設(shè)計(jì),臨湘網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專(zhuān)注于網(wǎng)站建設(shè)10多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專(zhuān)業(yè)建站公司;建站業(yè)務(wù)涵蓋:臨湘等地區(qū)。臨湘做網(wǎng)站價(jià)格咨詢:18980820575

2、然后備份新安裝的MY.INI和DATA這兩個(gè)目錄,直接將其原來(lái)mysql/data下的文件拷到新安裝的mysql/data目錄下即可;

3、啟動(dòng)MysQL服務(wù)。該方法只在新安裝的數(shù)據(jù)庫(kù)與舊數(shù)據(jù)庫(kù)版本相同的情況下實(shí)驗(yàn)成果。重新打開(kāi)navicat,發(fā)現(xiàn)原來(lái)的數(shù)據(jù)庫(kù)都可以使用了。

mysql還原數(shù)據(jù)庫(kù)

簡(jiǎn)單情況下:進(jìn)入原來(lái)mysql安裝路徑下的data文件夾下,找到相應(yīng)的庫(kù)和ibdata1,進(jìn)行copy,就可回復(fù)原來(lái)的數(shù)據(jù)。

復(fù)雜情況下:

從另一臺(tái)機(jī)上把MySQL數(shù)據(jù)庫(kù)的mysql文件夾拷貝到本地機(jī)上,目的是恢復(fù)本地機(jī)對(duì)數(shù)據(jù)的訪問(wèn)和操作。經(jīng)過(guò)如下幾種情況的操作。

1. 在本地重裝MySQL(安裝目錄D:\Program Files\MySQL\MySQL Server 5.0),直接把mysql文件夾拷貝至D:\Program Files\MySQL\MySQL Server 5.0\。結(jié)果,失?。簲?shù)據(jù)庫(kù)連接錯(cuò)誤。

2. 卸載后重裝MySQL,將D:\Program Files\MySQL\MySQL Server 5.0\下的數(shù)據(jù)備份,只把mysql\data文件夾全部?jī)?nèi)容拷貝到D:\Program Files\MySQL\MySQL Server 5.0\data下。結(jié)果,失敗:數(shù)據(jù)庫(kù)連接錯(cuò)誤。將備份的數(shù)據(jù)還完覆蓋。結(jié)果,失敗,還是連接不上數(shù)據(jù)庫(kù)。

3. 卸載后重裝MySQL,將mysql\data文件夾里的cf1,last文件夾(這兩個(gè)是原來(lái)MySQL里的數(shù)據(jù)庫(kù))拷貝進(jìn)D:\Program Files\MySQL\MySQL Server 5.0\data。連接成功,在Navicat for MySQL里看到數(shù)據(jù)庫(kù)cf1和last,但是不能訪問(wèn),因?yàn)閿?shù)據(jù)全為零。明白了原來(lái)data里以數(shù)據(jù)庫(kù)命名的文件存儲(chǔ)的是數(shù)據(jù)庫(kù)的表結(jié)構(gòu),不是元數(shù)據(jù)。下一步,把data文件夾里的ibdata1文件(3.4G大,明顯存儲(chǔ)了元數(shù)據(jù))拷貝到D:\Program Files\MySQL\MySQL Server 5.0\data里,代替原來(lái)的ibdata1文件。重啟電腦,打開(kāi)Navicat for MySQL,連接成功,數(shù)據(jù)可以訪問(wèn)操作。

至此,操作終于成功。其實(shí)當(dāng)初在那臺(tái)機(jī)上把數(shù)據(jù)導(dǎo)出來(lái),而不是現(xiàn)在直接把文件夾mysql復(fù)制過(guò)來(lái)會(huì)更容易恢復(fù)。但那臺(tái)機(jī)已經(jīng)重裝了系統(tǒng),也就是說(shuō)MySQL失效了。

mysql怎么通過(guò)frm和ibd文件還原數(shù)據(jù)?

1、找回表結(jié)構(gòu),如果表結(jié)構(gòu)沒(méi)有丟失直接到下一步\x0d\x0a\x0d\x0aa、先創(chuàng)建一個(gè)數(shù)據(jù)庫(kù),這個(gè)數(shù)據(jù)庫(kù)必須是沒(méi)有表和任何操作的。\x0d\x0a\x0d\x0ab、創(chuàng)建一個(gè)表結(jié)構(gòu),和要恢復(fù)的表名是一樣的。表里的字段無(wú)所謂。一定要是innodb引擎的。CREATE TABLE `weibo_qq0`( `weiboid` bigint(20)) ENGINE=InnoDB DEFAULT CHARSET=utf8;\x0d\x0a\x0d\x0ac、關(guān)閉mysql, service mysqld stop;\x0d\x0a\x0d\x0ad、用需要恢復(fù)的frm文件覆蓋剛新建的frm文件;\x0d\x0a\x0d\x0ae、修改my.ini 里 innodb_force_recovery=1 , 如果不成修改為 2,3,4,5,6。\x0d\x0a\x0d\x0af、 啟動(dòng)mysql,service mysqld start;show create table weibo_qq0 就能li到表結(jié)構(gòu)信息了。\x0d\x0a\x0d\x0a2、找回?cái)?shù)據(jù)。記得上面把 innodb_force_recovery改掉了,需要注釋掉,不然恢復(fù)模式不好操作。 這里有個(gè)關(guān)鍵的問(wèn)題,就是innodb里的任何數(shù)據(jù)操作都是一個(gè)日志的記錄點(diǎn)。也就是如果我們需要數(shù)據(jù)恢復(fù),必須把之前的表的數(shù)據(jù)的日志記錄點(diǎn)添加到一致。\x0d\x0a\x0d\x0aa、建立一個(gè)數(shù)據(jù)庫(kù),根據(jù)上面導(dǎo)出的創(chuàng)建表的sql執(zhí)行創(chuàng)建表。\x0d\x0a\x0d\x0ab、找到記錄點(diǎn)。先要把當(dāng)前數(shù)據(jù)庫(kù)的表空間廢棄掉,使當(dāng)前ibd的數(shù)據(jù)文件和frm分離。 ALTER TABLE weibo_qq0 DISCARD TABLESPACE;\x0d\x0a\x0d\x0ac、把之前要恢復(fù)的 .ibd文件復(fù)制到新的表結(jié)構(gòu)文件夾下。 使當(dāng)前的ibd 和frm發(fā)生關(guān)系。ALTER TABLE weibo_qq0 IMPORT TABLESPACE; 結(jié)果不出意外肯定會(huì)報(bào)錯(cuò)。就和我們開(kāi)展數(shù)據(jù)開(kāi)始說(shuō)的那樣,數(shù)據(jù)記錄點(diǎn)不一致。我們看看之前ibd記錄的點(diǎn)在什么位置。開(kāi)始執(zhí)行 import tablespace,報(bào)錯(cuò) ERROR 1030 (HY000): Got error -1 from storage engine。找到mysql的錯(cuò)誤日志,InnoDB: Error: tablespace id in file ‘.testweibo_qq0.ibd’ is 112, but in the InnoDB InnoDB: data dictionary it is 1. 因?yàn)?weibo_qq0 之前的記錄點(diǎn)在112,當(dāng)前的表只創(chuàng)建一次,所以記錄點(diǎn)是1.\x0d\x0a\x0d\x0ad、那怎么從1記錄到112。for ($1=1; $i

回答于?2022-11-16

mysql的數(shù)據(jù)刪除后怎么恢復(fù)

如果你要恢復(fù)的數(shù)據(jù)庫(kù)是包含授權(quán)表的mysql數(shù)據(jù)庫(kù),您將需要使用--skip贈(zèng)款-tables選項(xiàng)來(lái)運(yùn)行服務(wù)器恢復(fù)整個(gè)數(shù)據(jù)庫(kù)

- 首先,。否則,服務(wù)器會(huì)抱怨不能找到授權(quán)表?;謴?fù)表后,執(zhí)行mysqladmin沖水privileges告訴服務(wù)器裝載授權(quán)表,并用它們來(lái)啟動(dòng)。數(shù)據(jù)庫(kù)目錄到其他地方的原始內(nèi)容

復(fù)制。例如,您可以使用它們?cè)谝院蟮氖潞蠓治鰴z查表(驗(yàn)尸)的崩潰。

酒店與最新的數(shù)據(jù)庫(kù)備份文件重新加載。如果您打算使用mysqldump的所加載的文件,則需要輸入它們作為mysql的。如果您打算使用從數(shù)據(jù)庫(kù)文件直接拷貝(例如,使用tar或CP),它會(huì)復(fù)制他們直接回?cái)?shù)據(jù)庫(kù)目錄中。然而,在這種情況下,你應(yīng)該在關(guān)閉之前,該服務(wù)器復(fù)制這些文件,然后重新啟動(dòng)它。在備份過(guò)程中

重做日志,然后查詢更新數(shù)據(jù)庫(kù)表中。對(duì)于所有可用的更新日志,你可以使用它作為mysql的輸入。指定--one-database選項(xiàng),因此MySQL只是要還原的數(shù)據(jù)庫(kù)執(zhí)行查詢。如果你意識(shí)到有必要使用所有的更新日志文件,可以使用包含以下命令日志的目錄:

%LS-TRL更新(0-9)* | xargs的貓| mysql--。一個(gè)數(shù)據(jù)庫(kù)DB_NAME

ls命令生成一個(gè)單獨(dú)的日志文件更新列表,更新日志文件根據(jù)服務(wù)器(你知道,如果你其中的任何文件,排序順序生成的順序進(jìn)行排序會(huì)發(fā)生變化,這將導(dǎo)致在更新日志中以錯(cuò)誤的順序使用)。有限公司您可能需要使用一些更新日志。例如,如果日志,因?yàn)槊鹵pdate.392備份,pdate.393等產(chǎn)生的,可以在命令重新運(yùn)行它們:

%的mysql - 一個(gè)數(shù)據(jù)庫(kù)DB_NAME 錄入。 392

%的mysql - 一個(gè)數(shù)據(jù)庫(kù)DB_NAME updata.393 ...

如果您正在運(yùn)行的恢復(fù),并打算使用更新日志恢復(fù)由于失誤降數(shù)據(jù)的基礎(chǔ)上,DROPTABLE或DELETE語(yǔ)句和丟失的信息時(shí),一定要在開(kāi)始更新日志刪除這些語(yǔ)句。

恢復(fù)單個(gè)表

恢復(fù)單個(gè)表是非常困難的。如果是的mysqldump備份文件生成的,它只是不包含數(shù)據(jù),您需要一個(gè)表,你需要提取的相關(guān)線路,并利用它們作為mysql的輸入,這部分比較容易。困難的是,提取在該表的更新日志中使用的片段。你會(huì)發(fā)現(xiàn):mysql_find_rows工具在這方面有所幫助,它可以提取多行從更新日志查詢。另一種可能性是使用另一臺(tái)服務(wù)器

恢復(fù)整個(gè)數(shù)據(jù)庫(kù),然后將該文件復(fù)制到表的原始數(shù)據(jù)庫(kù)。這其實(shí)很容易!當(dāng)文件被復(fù)制回?cái)?shù)據(jù)庫(kù)目錄,確保原始數(shù)據(jù)庫(kù)服務(wù)器關(guān)閉。

網(wǎng)站題目:mysql怎么還原文件 mysql怎么還原數(shù)據(jù)庫(kù)
轉(zhuǎn)載來(lái)源:http://bm7419.com/article20/dohjhjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊(cè)、移動(dòng)網(wǎng)站建設(shè)、定制開(kāi)發(fā)、定制網(wǎng)站網(wǎng)站設(shè)計(jì)、小程序開(kāi)發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司