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

mysql表物理文件被誤刪的解決方法

 更新時(shí)間:2016年11月18日 14:20:42   投稿:daisy  
最近因?yàn)槭д`不小心誤刪了mysql表的物理文件,這個(gè)時(shí)候該怎么辦呢?然后抓緊從網(wǎng)上找解決的方法,終于解決了,現(xiàn)在將解決的方法及過程分享給大家,有需要的朋友們可以參考借鑒,感興趣的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

      1、該方法只介紹了如何救回這個(gè)表名(數(shù)據(jù)不恢復(fù)) 如果想要恢復(fù)原來數(shù)據(jù) 直接用extundelete把文件恢復(fù)后放回去即可

      2、并且是適用于平時(shí)沒有全備的情況下  如果有全備 直接那全備的frm和idb文件放回去 就可以了

      3、該方法同樣適用于數(shù)據(jù)表遷移(只遷移一個(gè)表)  因?yàn)閐iscard再import的速度 遠(yuǎn)比先dump再恢復(fù)的速度要快得多

建議: 平時(shí)備份一下表結(jié)構(gòu)是非常重要的

-- 如果你直接刪除了mysql的表文件 (.frm .idb)  在mysql5.6 可能你就悲劇了  可能再也用不回這個(gè)表名了

例子如下

-- 全在datadir目錄下操作

-- 直接刪除了表 tracking20160501的物理文件

rm -rf tracking20160501.*       
-- 刪除了表tracking20160501的frm文件和idb文件

-- 此時(shí)在數(shù)據(jù)庫已經(jīng)看不到該表

mysql> show tables;                            
-- 查看數(shù)據(jù)庫表

-- 但若想再創(chuàng)建該表或刪除該表  也許就悲劇了

mysql> create table tracking20160501(id int);
ERROR 1050 (42S01): Table 'tracking20160501' already exists            
-- 明明已經(jīng)看不到該表了 卻顯示表已存在
mysql> drop table tracking20160501;
ERROR 1051 (42S02): Unknown table 'kdnet_analyze.tracking20160501'    
-- 悲劇了吧 創(chuàng)建不到也刪不到。。

-- 查看一下現(xiàn)在的物理文件情況

ls tracking20160501.*
tracking20160501.ibd               
 -- 之前刪除了的表空間文件 他自己又創(chuàng)建了個(gè)出來 可能是剛剛的create table命令導(dǎo)致的 這里不用理

原因: 由于直接刪除了表的物理文件 但mysql的信息庫 information_schema 或 mysql 庫對該表的信息還存在(具體記在哪里 還沒找出來) 導(dǎo)致mysql還認(rèn)為該表存在 所以創(chuàng)建不了 刪除表時(shí)由于又找不到對應(yīng)的物理文件 所以也刪除不了  這樣??! 難道這個(gè)表名就無法再用了嗎? 

有解決方法 如下

-- 找其他表(最好是表結(jié)構(gòu)一樣的) 這里找的表叫ip_taobao 先復(fù)制這個(gè)表的.frm(表結(jié)構(gòu))文件 改名為誤刪的表名

cp -a ip_taobao.frm tracking20160501.frm            
-- 這里為了保持mysql文件的擁有人和所屬組 所以使用-a參數(shù)

-- 如果下面的操作有什么奇葩問題 可以重啟一下數(shù)據(jù)庫
-- 在mysql里 使用discard space命令 廢棄誤刪表的表空間文件

alter table tracking20160501 discard tablespace;

-- 再復(fù)制ip_taobao表的表空間文件 改名為誤刪的表名

cp -a ip_taobao.ibd tracking20160501.ibd            -- 同樣使用-a 保持擁有人和所屬組

-- 在mysql里 使用import space命令 導(dǎo)入新的表空間文件

mysql> alter table tracking20160501 import tablespace;       -- 導(dǎo)入時(shí)間可能會(huì)長點(diǎn)
Query OK, 0 rows affected, 5 warnings (7 min 36.94 sec)

-- 現(xiàn)在可以正常查詢、刪除和創(chuàng)建回這個(gè)表了

mysql> select * from tracking20160501 limit 1
mysql> drop table tracking20160501;
mysql> create table tracking20160501(id int);

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

相關(guān)文章

  • 詳解MySQL執(zhí)行原理、邏輯分層、更改數(shù)據(jù)庫處理引擎

    詳解MySQL執(zhí)行原理、邏輯分層、更改數(shù)據(jù)庫處理引擎

    在本文里我們給大家總結(jié)了關(guān)于MySQL執(zhí)行原理、邏輯分層、更改數(shù)據(jù)庫處理引擎的相關(guān)知識(shí)點(diǎn),需要的讀者們一起學(xué)習(xí)下。
    2019-02-02
  • MYSQL 根據(jù)唯一索引鍵更新死鎖問題解析

    MYSQL 根據(jù)唯一索引鍵更新死鎖問題解析

    這篇文章主要介紹了MYSQL 根據(jù)唯一索引鍵更新死鎖問題解析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-10-10
  • Mysql數(shù)據(jù)庫函數(shù)之函數(shù)的用法小結(jié)

    Mysql數(shù)據(jù)庫函數(shù)之函數(shù)的用法小結(jié)

    函數(shù)只是對查詢結(jié)果中的數(shù)據(jù)進(jìn)行處理,不會(huì)改變數(shù)據(jù)庫中數(shù)據(jù)表的值,MySQL中的函數(shù)主要分為單行函數(shù)和多行函數(shù)兩大類,下面我們將詳細(xì)講解這兩大類函數(shù),這篇文章主要介紹了Mysql數(shù)據(jù)庫函數(shù)之函數(shù)的用法,需要的朋友可以參考下
    2022-11-11
  • redhat 5.4下安裝MYSQL全過程

    redhat 5.4下安裝MYSQL全過程

    自己需要的是用JAVA環(huán)境而不是用php+apache這種一鍵安裝的東西,所以果斷自己來安裝自己想要的東西了,下面與大家分享下redhat 5.4下安裝MYSQL全過程,感興趣的朋友可以參考下哈
    2013-06-06
  • dbeaver導(dǎo)入sql腳本的詳細(xì)步驟(附圖文)

    dbeaver導(dǎo)入sql腳本的詳細(xì)步驟(附圖文)

    這篇文章主要給大家介紹了關(guān)于dbeaver導(dǎo)入sql腳本的詳細(xì)步驟,DBeaver是一款數(shù)據(jù)庫管理工具,最重要的是他是一款比較好的開源工具,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09
  • linux忘記mysql密碼處理方法

    linux忘記mysql密碼處理方法

    這篇文章主要為大家介紹下linux忘記mysql密碼處理方法,需要的朋友可以參考下。
    2011-08-08
  • 怎樣設(shè)置才能允許外網(wǎng)訪問MySQL

    怎樣設(shè)置才能允許外網(wǎng)訪問MySQL

    大多數(shù)情況下,mysql數(shù)據(jù)庫只要本機(jī)訪問就可以了,這樣的話,默認(rèn)安裝就OK,但是如果需要外網(wǎng)訪問mysql數(shù)據(jù)庫的話,應(yīng)該如何操作呢,想知道的話,就好好看看下面的介紹吧
    2014-08-08
  • 在Python安裝MySQL支持模塊的方法

    在Python安裝MySQL支持模塊的方法

    這篇文章來給各位同學(xué)詳細(xì)介紹關(guān)于在Python安裝MySQL支持模塊有需要了解的朋友可參考
    2013-08-08
  • mysql中找不到my.ini文件的問題及解決

    mysql中找不到my.ini文件的問題及解決

    這篇文章主要介紹了mysql中找不到my.ini文件的問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • CentOS安裝MySQL5.5的完整步驟

    CentOS安裝MySQL5.5的完整步驟

    MySQL是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)之一,在 WEB 應(yīng)用方面MySQL是最合適的數(shù)據(jù)庫,這篇文章主要給大家介紹了關(guān)于CentOS安裝MySQL5.5的相關(guān)資料,需要的朋友可以參考下
    2021-11-11

最新評(píng)論