【教程】SQLite資料庫修複

來源:互聯網
上載者:User

標籤:

SQLite 大家都知道,就不多說了。

有時候資料量大了,或者預存程序中出現異常,資料庫就可能會出問題。

這是以前公司產品出現過的問題,導致軟體都打不開了,我花了不少時間才解決的,趁現在有空貢獻出來。

 

  1. 先下載一個 sqlite3 的命令列工具,下載對應系統版本的  command-line shell

  2. 下載完成後解壓到一個目錄下,順便把要修複的資料庫也放到該目錄下。

  3. 開啟終端(CMD)進入到該目錄。

  4. 執行以下命令: sqlite3 要修複的資料庫名.output "_temp.tmp".dump.quit 該命令是將舊資料庫的內容提取出來,儲存到一個臨時檔案中
  5. 用編輯器開啟剛剛產生臨時檔案 _temp.tmp 看看檔案的最後一行是不是 ROLLBACK; -- due to errors 是則把它刪掉,並加上 COMMIT; 如果最後一行是 COMMIT; 則忽略此步驟。
  6. 再到終端,輸入一下命令: sqlite3 新資料庫名.read "_temp.tmp".quit 此命令是將舊資料寫到新資料庫裡面。
  7. 至此,資料庫修複完畢。可能有點小缺陷,資料會丟失一小部分,不過至少大部分資料都還在,資料庫也能繼續使用了。

【教程】SQLite資料庫修複

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.