VFP 愛用者社區 首頁 VFP 愛用者社區
本討論區為 Visual Foxpro 愛用者經驗交流的地方, 請多多利用"搜尋"的功能, 先查看看有無前例可循, 如果還有不懂的再發問. 部份主題有附加檔案, 須先註冊成為社區居民才可以下載.
 
 常見問題常見問題   搜尋搜尋   會員列表會員列表   會員群組會員群組   會員註冊會員註冊 
 個人資料個人資料   登入檢查您的私人訊息登入檢查您的私人訊息   登入登入 

sqlserver 異常問題!!!

 
發表新主題   回覆主題    VFP 愛用者社區 首頁 -> SQL 討論區
上一篇主題 :: 下一篇主題  
發表人 內容
ezpos



註冊時間: 2011-04-20
文章: 280


第 1 樓

發表發表於: 星期三 五月 04, 2016 10:38 pm    文章主題: sqlserver 異常問題!!! 引言回覆

sqlserver 異常問題!!!

請問大大這要如何解決???

_________________
ezPos收銀機 簡單好用低成本 http://www.ezpos.info
全新美觀的POS收銀機.POS軟硬體耗材.
軟體客制化.網站規劃....能賺錢的都可以找我

http://www.twelife.com 台灣生活網
回頂端
檢視會員個人資料 發送私人訊息 參觀發表人的個人網站
syntech



註冊時間: 2003-05-16
文章: 3820
來自: Taipei,Taiwan

第 2 樓

發表發表於: 星期四 五月 05, 2016 8:39 am    文章主題: 引言回覆

http://www.wangchao.net.cn/bbsdetail_1785769.html

底下 簡翻繁:
----

SQL Server 2000數據庫不知什麼原因變成置疑,在企業管理器裡面看是置疑,在DATA裡面有MDF和LOG這兩個文件,換一台機器附加時報錯:
  
  錯誤:3624
  location: recovery:2446
  EXpression: seenCkpEnd
  SPID: 51
  process ID: 348
  備份數據文件,然後按以下的步驟來進行處理:
  1.新建一個同名的數據庫(數據文件與原來的要一致)
  2.再停掉sql server(注意不要分離數據庫)
  3.用原數據庫的數據文件覆蓋掉這個新建的數據庫
  4.再重啟sql server
  5.此時打開企業管理器時會出現置疑,先不管,執行下面的語句(注意修改其中的數據庫名)
  
  USE MASTER
  GO
  SP_CONFIGURE 'ALLOW UPDATES',1 RECONFIGURE WITH OVERRIDE
  GO
  UPDATE SYSDATABASES SET STATUS =32768 WHERE NAME='置疑的數據庫名'
  Go
  sp_dboption '置疑的數據庫名', 'single user', 'true'
  Go
  DBCC CHECKDB('置疑的數據庫名')
  Go
  update sysdatabases set status =28 where name='置疑的數據庫名'
  Go
  sp_configure 'allow updates', 0 reconfigure with override
  Go
  sp_dboption '置疑的數據庫名', 'single user', 'false'
  Go
  6.完成後一般就可以訪問數據庫中的數據了,這時,數據庫本身一般還要問題,解決辦法是,利用數據庫的腳本創建一個新的數據庫,並將數據導進去就行了。
  SQL Server數據庫文件恢復技術:
  SQL Server數據庫備份有兩種方式,一種是使用BACKUP DATABASE將數據庫文件備份出去,另外一種就是直接拷貝數據庫文件mdf和日誌文件ldf的方式。下面將主要討論一下後者的備份與恢復。本文假定您能熟練使用SQL Server Enterprise Manager(SQL Server企業管理器)和SQL Server Quwey Analyser(SQL Server查詢分析器)
  1、正常的備份、恢復方式
  正常方式下,我們要備份一個數據庫,首先要先將該數據庫從運行的數據服務器中斷開,或者停掉整個數據庫服務器,然後複製文件。
  卸下數據庫的命令:Sp_detach_db 數據庫名
  連接數據庫的命令:Sp_attach_db或者sp_attach_single_file_db
  s_attach_db [@dbname =] ′dbname′, [@filename1 =] ′filename_n′ [,...16]
  sp_attach_single_file_db [@dbname =] ′dbname′, [@physname =] ′physical_name′
  使用此方法可以正確恢復SQL Sever7.0和SQL Server 2000的數據庫文件,要點是備份的時候一定要將mdf和ldf兩個文件都備份下來,mdf文件是數據庫數據文件,ldf是數據庫日誌文件。
  例子:
  假設數據庫為test,其數據文件為test_data.mdf,日誌文件為test_log.ldf。下面我們討論一下如何備份、恢復該數據庫。
  卸下數據庫:sp_detach_db 'test'
  連接數據庫:sp_attach_db 'test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_data.mdf','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf'
  sp_attach_single_file_db 'test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_data.mdf'
  
  2、只有mdf文件的恢復技術
  由於種種原因,我們如果當時僅僅備份了mdf文件,那麼恢復起來就是一件很麻煩的事情了。
  如果您的mdf文件是當前數據庫產生的,那麼很僥倖,也許你使用sp_attach_db或者sp_attach_single_file_db可以恢復數據庫,但是會出現類似下面的提示信息
  設備激活錯誤。物理文件名 'C:\Program Files\Microsoft SQL Server\MSSQL\data\test_Log.LDF' 可能有誤。
  已創建名為 'C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.LDF' 的新日誌文件。
  但是,如果您的數據庫文件是從其他計算機上複製過來的,那麼很不幸,也許上述辦法就行不通了。你也許會得到類似下面的錯誤信息
  服務器: 消息 1813,級別 16,狀態 2,行 1
  未能打開新數據庫 'test'。CREATE DATABASE 將終止。
  設備激活錯誤。物理文件名 'd:\test_log.LDF' 可能有誤。
  怎麼辦呢?別著急,下面我們舉例說明恢復辦法。
  A.我們使用默認方式建立一個供恢復使用的數據庫(如test)。可以在SQL Server Enterprise Manager裡面建立。
  B.停掉數據庫服務器。
  C.將剛才生成的數據庫的日誌文件test_log.ldf刪除,用要恢復的數據庫mdf文件覆蓋剛才生成的數據庫數據文件test_data.mdf。
  D.啟動數據庫服務器。此時會看到數據庫test的狀態為「置疑」。這時候不能對此數據庫進行任何操作。
  E.設置數據庫允許直接操作系統表。此操作可以在SQL Server Enterprise Manager裡面選擇數據庫服務器,按右鍵,選擇「屬性」,在「服務器設置」頁面中將「允許對系統目錄直接修改」一項選中。也可以使用如下語句來實現。
  
  use master
  go
  sp_configure 'allow updates',1
  go
  reconfigure with override
  go
  F.設置test為緊急修復模式
  update sysdatabases set status=-32768 where dbid=DB_ID('test')
  此時可以在SQL Server Enterprise Manager裡面看到該數據庫處於「只讀\置疑\脫機\緊急模式」可以看到數據庫裡面的表,但是僅僅有系統表
  G.下面執行真正的恢復操作,重建數據庫日誌文件
  dbcc rebuild_log('test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf')
  執行過程中,如果遇到下列提示信息:
  服務器: 消息 5030,級別 16,狀態 1,行 1
  未能排它地鎖定數據庫以執行該操作。
  DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯繫。[brown][/i]
  說明您的其他程序正在使用該數據庫,如果剛才您在F步驟中使用SQL Server Enterprise Manager打開了test庫的系統表,那麼退出SQL Server Enterprise Manager就可以了。
  正確執行完成的提示應該類似於:
  警告: 數據庫 'test' 的日誌已重建。已失去事務的一致性。應運行 DBCC CHECKDB 以驗證物理一致性。將必須重置數據庫選項,並且可能需要刪除多餘的日誌文件。
  DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯繫。
  此時打開在SQL Server Enterprise Manager裡面會看到數據庫的狀態為「只供DBO使用」。此時可以訪問數據庫裡面的用戶表了。
  H.驗證數據庫一致性(可省略)
  dbcc checkdb('test')
  一般執行結果如下:
  CHECKDB 發現了 0 個分配錯誤和 0 個一致性錯誤(在數據庫 'test' 中)。
  DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯繫。
  I.設置數據庫為正常狀態
  sp_dboption 'test','dbo use only','false'
  如果沒有出錯,那麼恭喜,現在就可以正常的使用恢復後的數據庫啦。
  J.最後,我們需要將步驟E中設置的「允許對系統目錄直接修改」一項恢復。因為平時直接操作系統表是一件比較危險的事情。當然,我們可以在SQL Server Enterprise Manager裡面恢復,同時也可以使用下面的語句來完成。
  
  sp_configure 'allow updates',0
  go
  reconfigure with override
  go

_________________
如果公司有下列困擾:
1. 找不到便宜,快速,簡易的 生產排程軟體
2. 不知道如何快速排定 採購計劃
3. 成本抓不準,自己算比軟體算有用
4. 想學習系統規劃,想找系統架構的顧問

請聯絡我們,也許我們幫得上忙
回頂端
檢視會員個人資料 發送私人訊息 發送電子郵件 AIM Address
ezpos



註冊時間: 2011-04-20
文章: 280


第 3 樓

發表發表於: 星期四 五月 05, 2016 11:30 am    文章主題: 引言回覆

謝謝S大

底下有效果喔~~~~改天請你吃飯....太感謝你了



代碼:
USE MASTER
  GO
  SP_CONFIGURE 'ALLOW UPDATES',1 RECONFIGURE WITH OVERRIDE
  GO
  UPDATE SYSDATABASES SET STATUS =32768 WHERE NAME='置疑的數據庫名'
  Go
  sp_dboption '置疑的數據庫名', 'single user', 'true'
  Go
  DBCC CHECKDB('置疑的數據庫名')
  Go
  update sysdatabases set status =28 where name='置疑的數據庫名'
  Go
  sp_configure 'allow updates', 0 reconfigure with override
  Go
  sp_dboption '置疑的數據庫名', 'single user', 'false'
  Go

_________________
ezPos收銀機 簡單好用低成本 http://www.ezpos.info
全新美觀的POS收銀機.POS軟硬體耗材.
軟體客制化.網站規劃....能賺錢的都可以找我

http://www.twelife.com 台灣生活網
回頂端
檢視會員個人資料 發送私人訊息 參觀發表人的個人網站
從之前的文章開始顯示:   
發表新主題   回覆主題    VFP 愛用者社區 首頁 -> SQL 討論區 所有的時間均為 台北時間 (GMT + 8 小時)
1頁(共1頁)

 
前往:  
無法 在這個版面發表文章
無法 在這個版面回覆文章
無法 在這個版面編輯文章
無法 在這個版面刪除文章
無法 在這個版面進行投票
無法 在這個版面附加檔案
無法 在這個版面下載檔案


Powered by phpBB © 2001, 2005 phpBB Group
正體中文語系由 phpbb-tw 維護製作