版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、v1.0可編輯可修改SQL Serve系統(tǒng)表損壞的處理方法、SQL SV戡據(jù)庫中三張重要的系統(tǒng)表sysobjects :在數(shù)據(jù)庫內(nèi)創(chuàng)建的每個(gè)對象(約束、默認(rèn)值、日志、規(guī)則、存儲(chǔ)過程等)在表中占一行sysindexes :數(shù)據(jù)庫中的每個(gè)索引和表在表中各占一行。syscolumns:每個(gè)表和視圖中的每列在表中占一行,存儲(chǔ)過程中的每個(gè)參數(shù)在表中也占一行這三張表用ID (表ID)字段關(guān)聯(lián)。這三張系統(tǒng)表一旦損壞,與之對應(yīng)數(shù)據(jù)庫對象將無法訪問,其作用相當(dāng)于 DO中的“文件分配表”。二、系統(tǒng)表損壞的癥狀用DBCCCHECKDB帶任何參數(shù)都無法修復(fù)數(shù)據(jù)庫,也就是說:DBCCHECKDB對這個(gè)帳套根本不起作用;
2、無法執(zhí)行如下操作:select * from sysobjects 或 select * from sysindexes或 select * from syscolumns ;無法用SQL server DTS或其他SQL腳本導(dǎo)庫工具進(jìn)行導(dǎo)庫,導(dǎo)庫的中途失 敗,報(bào)告:連接中斷;在企業(yè)管理器或查詢分析器中,部分用戶數(shù)據(jù)表無法訪問。三、處理方法處理這種數(shù)據(jù)庫,分為兩個(gè)大的步驟:第一步:處理可以訪問的數(shù)據(jù)表1)找出哪些表不可訪問,即:系統(tǒng)表中哪些記錄損壞;2)用SQL server DTS把能夠訪問的用戶數(shù)據(jù)表導(dǎo)入一個(gè)新的 DataBase 在導(dǎo)庫時(shí),不能選折(1)中不能訪問的數(shù)據(jù)表。第二步:處理不
3、可訪問的數(shù)據(jù)表:1)找出系統(tǒng)表中錯(cuò)誤記錄的ID;2)根據(jù)“錯(cuò)誤記錄的 ID“,刪除 sysobjects 、 sysindexes、syscolumns 表 錯(cuò)誤的記錄;3)根據(jù)“錯(cuò)誤記錄的ID” ,重建系統(tǒng)表記錄;4)重建完畢,如果該表可以訪問,那么用DTS單獨(dú)將此表導(dǎo)入新的DataBase。說明:重建系統(tǒng)表方式不一定會(huì)成功,比如由于DISK I/O錯(cuò)誤,如果僅僅是保存系統(tǒng)表的磁盤扇區(qū)出錯(cuò),那么重建系統(tǒng)表方式可以挽回?cái)?shù)據(jù)。如果保存用戶數(shù)據(jù)表的磁盤扇區(qū)出錯(cuò),那么即使重建系統(tǒng)表也不能解決問題。如果重要的用戶數(shù)據(jù)表無法導(dǎo)庫,如:t_Voucher、IcStockbill 、ICSale等,那么可以
4、用用“第二步”中的方法一試。四、例例:一 sql svr數(shù)據(jù)庫,實(shí)體名為:AIS181217用dbcc checkDBM,報(bào)告(用dbcc checkDB任何參數(shù)者b是以下提示):服務(wù)器:消息8966 ,級別16 ,狀態(tài)1 ,行1未能讀取并閂鎖頁(1:29262)(用閂鎖類型 SH)。SYSOBJECT趺敗。DBCC執(zhí)行完畢。如果 DBCC輸出了錯(cuò)誤信息,請與系統(tǒng)管理員聯(lián)系。執(zhí)行 select * from sysobjects ,報(bào)告如下:服務(wù)器:消息644 ,級別21,狀態(tài)3 ,行1未能在索引頁 (1:29262) 中找到 RID ' 16243a6d19100' 的索引條
5、目(索引 ID 0 , 數(shù)據(jù)庫AIS181217')。連接中斷但是執(zhí)行 select * from sysindexes 和 select * from syscolumns 正常。這說明只有 sysobjects 表損壞,而 sysindexes 和 syscolumns 沒有問題。22003/6/30v1.0可編輯可修改處理步驟:第一步:處理可以訪問的數(shù)據(jù)表找出哪些表不可訪問;新建立一個(gè)sql svr數(shù)據(jù)庫,數(shù)據(jù)庫實(shí)體名為AisNew。進(jìn)入查詢分析器,執(zhí)行如下SQL*use AIS181217DECLARTbNameVARCHA(R0)DECLARFindErrTable SCRO
6、LL CURSOR FORselect name from . sysobjects where xtype= 'u'order by nameOPENFindErrTableFETCHFindErrTable INTO TbNameWHILE FETCH_STA<USBEGIN+ TbName)print TbName exec( select top 1 * fromFETCHFindErrTable INTO TbNameENDPRINT 'Scan Complate CLOS田indErrTableDEALLOCATEindErrTable*執(zhí)行此SQ&q
7、uot;出的報(bào)告的最后幾行為:Tvoucher服務(wù)器:消息644 ,級別21 ,狀態(tài)3 ,行1未能在索引頁(1:29262) 中找到RID ' 161dd201a100 '的索引條目(索引ID 0 ,數(shù)據(jù)庫 'AIS181217')。連接中斷根據(jù)以上報(bào)告可以知道T_voucher表在sysobjects表中的對應(yīng)記錄出錯(cuò),造 成T_voucher不能訪問。修改上面的SQL在聲明游標(biāo)的記錄集中屏蔽 T_voucher表。 即:DECLARFindErrTable SCROLL CURSOR FORselect name from . sysobjects wher
8、e xtype= 'u' and name != ' t voucher order by name修改完畢,繼續(xù)執(zhí)行此SQL如此反復(fù),就能夠不斷報(bào)告出sysobjects中那些表不能訪問。導(dǎo)庫用SQL DTSX具將AIS181217中可以訪問的數(shù)據(jù)表導(dǎo)入 AisNew。第二步:處理不可訪問的數(shù)據(jù)表: 找出系統(tǒng)表中錯(cuò)誤記錄的ID- -獲得 AIS181217 中 T_voucher 表在 sysobjects 中的 ID :SELECTid FROM WHEREiame=' t_voucher '=» 123(說明:通常即使sysobjects
9、 表損壞,不能做select * from sysobjects 查詢, 但是可以做 select ID,name from sysobjects 查詢。如果 select ID,name from sysobjects 查詢也不能執(zhí)行,可以對照 AisNew和AIS181217兩個(gè)數(shù)據(jù)庫中的同名 表:syscolumns。根據(jù)表中T_voucher所占字段的個(gè)數(shù)以及各個(gè)字段的名稱,在中 找出T_voucher所對應(yīng)的記錄,由此獲得T_voucher在AIS181217數(shù)據(jù)庫的系統(tǒng)表42003/6/30v1.0可編輯可修改中所分配的ID。)- -獲得 AisNew 中 T_voucher 表在
10、 sysobjects 中的 ID :SELECTd FROM WHEREiame=' t_voucher ' =» 456刪除AIS181217中系統(tǒng)表中錯(cuò)誤記錄:DELETE WHEREI=123DELETE WHEREI=123DELETE WHEREI=123重建系統(tǒng)表記錄- -重建表中T_voucher表對應(yīng)的記錄:INSERT INTO(name,id,xtype,uid,info,status,base_schema_ver,replinfo,parent_obj,crdate,ftcatid) SELECT't_voucher_b '
11、,123,xtype,uid,info,status,base_schema_ver,replinfo,parent_obj,crda te,ftcatid FROM . sysobjects WHERid=456- -重建表中t_voucher表對應(yīng)的記錄:INSERT INTO (id,status,first,indid,root,minlen,keycnt,groupid,dpages,reserved,used,rowcnt,rowmodctr,reserved3,reserved4,xmaxlen,maxirow,OrigFillFactor,StatVersion,reserve
12、d2,Fir stIAM,impid,lockflags,pgmodctr,keys,name,statblob) SELECT123,status,first,indid,root,minlen,keycnt,groupid,dpages,reserved,used,rowcnt,rowm odctr,reserved3,reserved4,xmaxlen,maxirow,OrigFillFactor,StatVersion,reserved2,FirstIAM,impid,lockflags,pgmodctr,keys,name,statblobFROM WHEREd=456- -重建表中t_voucher表對應(yīng)的記錄:INSERT INTOSELECTname,123,xtype,typestat,xusertype,length,xprec,xscale,colid,xoffset,bitpos,reserved,colstat,cdefault,domain,number,colORDERBY,autoval,offset,collationid,languageFROM WHERid=456()用DT/獨(dú)將t_voucher_b表導(dǎo)入新的DataBase經(jīng)過以上操作,AIS181217中t_voucher_b 表與原t_voucher表共用同一
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 《弟子規(guī)》與2024年教育趨勢融合教學(xué)
- 2024年貝的故事:教學(xué)資源的整合與創(chuàng)新
- 2024年XX企業(yè)客戶服務(wù)文化建設(shè)方案
- 小學(xué)語文教學(xué)設(shè)計(jì)《棉花姑娘》
- 護(hù)理學(xué)基礎(chǔ)(護(hù)理???含答案))
- 2024-2025學(xué)年新教材高中英語課時(shí)分層作業(yè)一Unit1Laughoutloud含解析外研版選擇性必修第一冊
- 《操作系統(tǒng)教程》(5版)課堂或課后研討題
- 2024-2025學(xué)年高中數(shù)學(xué)第二章圓錐曲線與方程2.1拋物線及其標(biāo)準(zhǔn)方程課時(shí)作業(yè)含解析北師大版選修1-1
- 初中語文茶可道茶亦悠然閱讀練習(xí)及答案
- 高中政治統(tǒng)編版-選擇性必修三-《邏輯與思維》6.1推理與演繹推理概述
- 學(xué)校崗位廉政風(fēng)險(xiǎn)排查登記表
- 公司電梯安全總監(jiān)、電梯安全員崗位職責(zé)
- 02J331地溝及蓋板圖集
- 2019年西藏開發(fā)投資集團(tuán)有限公司招聘試題及答案解析
- HAY崗位管理體系構(gòu)建
- 2023年中級經(jīng)濟(jì)師考試真題及答案
- SB/T 10895-2012鮮蛋包裝與標(biāo)識(shí)
- GB/T 9115-2010對焊鋼制管法蘭
- GB/T 2423.3-2006電工電子產(chǎn)品環(huán)境試驗(yàn)第2部分:試驗(yàn)方法試驗(yàn)Cab:恒定濕熱試驗(yàn)
- GB/T 23221-2008烤煙栽培技術(shù)規(guī)程
- GB/T 16900-2008圖形符號(hào)表示規(guī)則總則
評論
0/150
提交評論