主頁 > 知識(shí)庫 > SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000)

SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000)

熱門標(biāo)簽:400電話辦理泰安 電話機(jī)器人怎么代理商 家庭農(nóng)場(chǎng)地圖標(biāo)注名稱怎樣起名 千呼電話機(jī)器人可以試用嗎 安卡拉地圖標(biāo)注app 互聯(lián)網(wǎng)電話外呼系統(tǒng) 零成本地圖標(biāo)注賺錢 我要地圖標(biāo)注數(shù)量有限制嗎 電銷需要外呼系統(tǒng)嗎

關(guān)于SQLSERVER 9003錯(cuò)誤解決方法 只適用于SQL2000:

"無法打開新數(shù)據(jù)庫 'POS'。CREATE DATABASE 中止。 (Microsoft SQL Server,錯(cuò)誤: 9003)"

看是9003錯(cuò)誤,就想到可能是由于日志文件的原因,再看數(shù)據(jù)庫文件可能損壞,于是想到dbcc checkdb指令.

方法如下:

1.我們使用默認(rèn)方式建立一個(gè)供恢復(fù)使用的數(shù)據(jù)庫(如pos)??梢栽赟QL Server Enterprise Manager里面建立。

2.停掉數(shù)據(jù)庫服務(wù)器。

3.將剛才生成的數(shù)據(jù)庫的日志文件pos_log.ldf刪除,用要恢復(fù)的數(shù)據(jù)庫mdf文件覆蓋剛才生成的數(shù)據(jù)庫數(shù)據(jù)文件

pos_data.mdf。

4.啟動(dòng)數(shù)據(jù)庫服務(wù)器。此時(shí)會(huì)看到數(shù)據(jù)庫pos的狀態(tài)為“置疑”。這時(shí)候不能對(duì)此數(shù)據(jù)庫進(jìn)行任何操作。

5.設(shè)置數(shù)據(jù)庫允許直接操作系統(tǒng)表。此操作可以在SQL Server Enterprise Manager里面選擇數(shù)據(jù)庫服務(wù)器,按右鍵,選擇“屬性”,在“服務(wù)器設(shè)置”頁面中將“允許對(duì)系統(tǒng)目錄直接修改”一項(xiàng)選中。也可以使用如下語句來實(shí)現(xiàn)。

use master 
go 
exec sp_configure 'allow updates',1 
go 
reconfigure with override 
go 

6.設(shè)置pos為緊急修復(fù)模式

update sysdatabases set status=-32768 where dbid=DB_ID('pos') 
go

此時(shí)可以在SQL Server Enterprise Manager里面看到該數(shù)據(jù)庫處于“只讀\置疑\脫機(jī)\緊急模式”可以看到數(shù)據(jù)庫里面的表,但是僅僅有系統(tǒng)表

7.下面執(zhí)行真正的恢復(fù)操作,重建數(shù)據(jù)庫日志文件

dbcc rebuild_log('pos','D:\Program Files\Microsoft SQL Server\MSSQL\Data\pos_log.ldf') 
go

執(zhí)行過程中,如果遇到下列提示信息:

服務(wù)器: 消息 5030,級(jí)別 16,狀態(tài) 1,行 1

未能排它地鎖定數(shù)據(jù)庫以執(zhí)行該操作。

DBCC 執(zhí)行完畢。如果 DBCC 輸出了錯(cuò)誤信息,請(qǐng)與系統(tǒng)管理員聯(lián)系。

說明您的其他程序正在使用該數(shù)據(jù)庫,如果剛才您在6步驟中使用SQL Server Enterprise Manager打開了pos庫的系統(tǒng)表,那么退出SQL Server Enterprise Manager就可以了。

正確執(zhí)行完成的提示應(yīng)該類似于:

警告: 數(shù)據(jù)庫 'pos' 的日志已重建。已失去事務(wù)的一致性。應(yīng)運(yùn)行 DBCC CHECKDB 以驗(yàn)證物理一致性。將必須重置數(shù)據(jù)庫選項(xiàng),并且可能需要?jiǎng)h除多余的日志文件。

DBCC 執(zhí)行完畢。如果 DBCC 輸出了錯(cuò)誤信息,請(qǐng)與系統(tǒng)管理員聯(lián)系。
此時(shí)打開在SQL Server Enterprise Manager里面會(huì)看到數(shù)據(jù)庫的狀態(tài)為“只供DBO使用”。此時(shí)可以訪問數(shù)據(jù)庫里面的用戶表了。

8.驗(yàn)證數(shù)據(jù)庫一致性(可省略)

dbcc checkdb('pos') 
go

一般執(zhí)行結(jié)果如下:

CHECKDB 發(fā)現(xiàn)了 0 個(gè)分配錯(cuò)誤和 0 個(gè)一致性錯(cuò)誤(在數(shù)據(jù)庫 'pos' 中)。
DBCC 執(zhí)行完畢。如果 DBCC 輸出了錯(cuò)誤信息,請(qǐng)與系統(tǒng)管理員聯(lián)系。

9.設(shè)置數(shù)據(jù)庫為正常狀態(tài)

exec sp_dboption 'pos','dbo use only','false' 
go

如果沒有出錯(cuò),那么恭喜,現(xiàn)在就可以正常的使用恢復(fù)后的數(shù)據(jù)庫啦。

10.最后一步,我們要將步驟E中設(shè)置的“允許對(duì)系統(tǒng)目錄直接修改”一項(xiàng)恢復(fù)。因?yàn)槠綍r(shí)直接操作系統(tǒng)表是一件比較危險(xiǎn)的事情。當(dāng)然,我們可以在SQL Server Enterprise Manager里面恢復(fù),也可以使用如下語句完成

exec sp_configure 'allow updates',0 
go 
reconfigure with override 
go

以上所述是小編給大家介紹的SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

您可能感興趣的文章:
  • sql server啟動(dòng)不了, MSSQL 18052錯(cuò)誤: 9003,嚴(yán)重度: 20,狀態(tài): 1 .
  • SQLSERVER啟動(dòng)不起來(錯(cuò)誤9003)的解決方法分享

標(biāo)簽:東營(yíng) 黃山 來賓 大同 池州 文山 新鄉(xiāng) 濱州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000)》,本文關(guān)鍵詞  SQL,SERVER,2000,9003,錯(cuò)誤,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000)》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL SERVER 2000 9003錯(cuò)誤的解決方法(只適用于SQL2000)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章