SQL SERVER資料恢複過程筆記

來源:互聯網
上載者:User

4月5日 要求SQL SERVER 2000資料庫ASIA因為硬碟損壞,經搶救後只取得了mdf和ldf檔案
開始以為只取得了MDF檔案,因此先進行
EXEC sp_attach_single_file_db  @dbname = N'ASIADB01',
   @physname = N'D:/Microsoft SQL Server/MSSQL/Data/ASIADB01_Data.mdf'
   但提示不成功;
   再次嘗試先建好一資料庫,再將其分離後,把記錄檔刪除掉,再執行掛接,仍不成功.

後來終於找到了記錄檔,經掛接成功,但探索資料庫顯示為唯讀,原來MDF是從光碟片上拷貝過來,檔案屬性為唯讀,改之後即可將資料庫唯讀屬性去掉.

EXEC sp_attach_db @dbname = N'ASIADB01',
   @filename1 = N'd:/Microsoft SQL Server/MSSQL/Data/ASIADB01_Data.mdf',
   @filename2 = N'd:/Microsoft SQL Server/MSSQL/Data/ASIADB01_log.ldf'

   後來執行ASIA應用程式,登陸等過程沒有問題,但在程式中在調用單號時顯示ADODC1報錯,[sql server] [odbc] 資料連線中斷,開始以為是
   應用程式方面的問題,因為包括作業系統,資料庫伺服器,應用程式等均為全新安裝,應用程式中也不時報出控制項未註冊的錯誤,一直懷疑是應用程式方面
   的錯誤.因為香港軟體供應商客服人員也一直在沿這個思路在解決問題,忙了一天未有任何成果.

   第二天我在自己電腦上安裝應用程式,用sql server事件探查器,監視出錯時執行的SQL語句,後COPY到查詢分析器中執行,發現以下問題:

SELECT ZKAKEH2.KASRDEN From ZKAKEH2

伺服器: 訊息 21,層級 24,狀態 1,行 1
警告: 嚴重錯誤 823 發生於 04  5 2005  7:43PM

串連中斷

SET ROWCOUNT 100000;
SELECT  TOP 1000 * FROM ZKAKEH2時沒有問題,但查取10000條記錄時即報串連中斷,初步可以判斷資料庫方面出了問題.

後用DBCC檢查表和資料庫時出現大量的錯誤
DBCC CHECKTABLE ('ZKAKEH2')
DBCC CHECKDB ('ASIADB01')

經用修複選項,終不能成功.
DBCC CHECKDB ('ASIADB01',REPAIR_REBUILD)
DBCC CHECKDB ('ASIADB01',repair_allow_data_loss)

沒辦法,採用先建立一個含同樣對象的資料庫,再用DTS從已壞的資料庫中將資料全數匯入進來.中間因為有幾個表在重建庫時輸入了資料,匯入資料不成功,
先將資料清除:
truncate table kparam3;
truncate table zhito;
truncate table zmoney;
truncate table ztrno;
重新匯入這四個表的資料,一切OK.
再用DBCC工具進行檢查,PASS,終於見到了一絲緒光.
重新設定應用程式ODBC,用程式進行串連,成功!謝天謝地.

總結:
資料庫應該及時進行備份(包括記錄備份),本CASE中就是因為缺少備份檔案,只有硬碟壞了之後搶救出來的MDF和LDF檔案,因此費了一番周折.在碰到這種問題時,
應先從資料庫方面考慮,而不是懷疑前端應用程式方面的問題:)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.