哈爾濱海月數(shù)據(jù)恢復(fù),技術(shù)亞洲領(lǐng)先 設(shè)為首頁加入收藏RSS訂閱
中國區(qū):哈爾濱(總部)、鄭州、福建深圳、沈陽合肥、大連、包頭淄博、上海廣州、
    南京杭州、嘉興、武漢濟(jì)南青島、新疆、太原
亞太區(qū):印度、韓國、泰國、新加坡馬來西亞、澳大利亞
Windows
sql server 系統(tǒng)表sysobjects、sysindexes、syscolumns 一致性錯誤修復(fù)方法

******步: 處理可以訪問的數(shù)據(jù)表
(1.1) 找出哪些表不可訪問;
新建立一個sql svr數(shù)據(jù)庫,數(shù)據(jù)庫實(shí)體名為AisNew。進(jìn)入查詢分析器,執(zhí)行如下SQL:
–****************************************************
use AIS20030529181217
DECLARE @TbName VARCHAR(80)
DECLARE FindErrTable SCROLL CURSOR FOR
select name from AisNew.dbo. sysobjects where xtype=‘u’ order by name
OPEN FindErrTable
FETCH FindErrTable INTO @TbName
WHILE @@FETCH_STATUS<>-1
BEGIN
print @TbName
exec( ‘select top 1 * from’ + @TbName)
FETCH FindErrTable INTO @TbName
END
PRINT ‘Scan Complate…’
CLOSE FindErrTable
DEALLOCATE FindErrTable
–****************************************************
執(zhí)行此SQL給出的報(bào)告的***后幾行為:

T_voucher
服務(wù)器: 消息 644,級別 21,狀態(tài) 3,行 1
未能在索引頁 (1:29262) 中找到 RID ‘161dd201a100′ 的索引條目(索引 ID 0,數(shù)據(jù)庫 ‘AIS20030529181217′)。
連接中斷

根據(jù)以上報(bào)告可以知道 T_voucher 表在sysobjects表中的對應(yīng)記錄出錯,造成T_voucher不能訪問。修改上面的SQL:在聲明游標(biāo)的記錄集中屏蔽T_voucher 表。即:

DECLARE FindErrTable SCROLL CURSOR FOR
select name from AisNew.dbo. sysobjects where xtype=‘u’ and name != ‘t_voucher’
order by name

修改完畢,繼續(xù)執(zhí)行此SQL。如此反復(fù),就能夠不斷報(bào)告出sysobjects中那些表不能訪問。
(1.2) 導(dǎo) 庫
用SQL DTS工具將AIS20030529181217中可以訪問的數(shù)據(jù)表導(dǎo)入AisNew。
第二步:處理不可訪問的數(shù)據(jù)表:
(2.1) 找出系統(tǒng)表中錯誤記錄的ID
–獲得AIS20030529181217中T_voucher表在sysobjects中的ID :
SELECT id FROM AIS20030529181217.dbo.sysobjects WHERE name=‘ t_voucher’
==》123
( 說明:通常即使sysobjects表損壞,不能做 select * from sysobjects 查詢,但是可以做 select ID,name from sysobjects 查詢。如果select ID,name from sysobjects 查詢也不能執(zhí)行,可以對照AisNew和AIS20030529181217兩個數(shù)據(jù)庫中的同名表: syscolumns。根據(jù)AisNew.dbo.syscolumns表中T_voucher所占字段的個數(shù)以及各個字段的名稱,在AIS20030529181217.dbo.syscolumns中找出T_voucher所對應(yīng)的記錄,由此獲得T_voucher在AIS20030529181217數(shù)據(jù)庫的系統(tǒng)表中所分配的ID。)

–獲得AisNew中T_voucher表在sysobjects中的ID :
SELECT id FROM AisNew.dbo.sysobjects WHERE name=‘ t_voucher’
==》456

(2.2) 刪除AIS20030529181217中系統(tǒng)表中錯誤記錄:
DELETE AIS20030529181217.dbo.sysobjects WHERE id=123
DELETE AIS20030529181217.dbo.sysindexes WHERE id=123
DELETE AIS20030529181217.dbo.syscolumns WHERE id=123

(2.3) 重建系統(tǒng)表記錄
–重建AIS20030529181217.dbo.sysobjects表中T_voucher表對應(yīng)的記錄:
INSERT INTO AIS20030529181217.dbo.sysobjects
(name,id,xtype,uid,info,status,base_schema_ver,replinfo,parent_obj,crdate,ftcatid)
SELECT
‘t_voucher_b’,123,xtype,uid,info,status,base_schema_ver,replinfo,parent_obj,crdate,ftcatid
FROM AisNew.dbo. sysobjects WHERE id=456

–重建AIS20030529181217.dbo.sysindexes表中t_voucher表對應(yīng)的記錄:
INSERT INTO AIS20030529181217.dbo.sysindexes
(id,status,first,indid,root,minlen,keycnt,groupid,dpages,reserved,used,rowcnt,rowmodctr,reserved3,reserved4,xmaxlen,maxirow,OrigFillFactor,StatVersion,reserved2,FirstIAM,impid,lockflags,pgmodctr,keys,name,statblob)
SELECT
123,status,first,indid,root,minlen,keycnt,groupid,dpages,reserved,used,rowcnt,rowmodctr,reserved3,reserved4,xmaxlen,maxirow,OrigFillFactor,StatVersion,reserved2,FirstIAM,impid,lockflags,pgmodctr,keys,name,statblob
FROM AisNew.dbo.sysindexes WHERE id=456

–重建AIS20030529181217.dbo.syscolumns表中t_voucher表對應(yīng)的記錄:
INSERT INTO AIS20030529181217.dbo.syscolumns
(name,id,xtype,typestat,xusertype,length,xprec,xscale,colid,xoffset,bitpos,reserved,colstat,cdefault,domain,number,colorderby,autoval,offset,collationid,language)
SELECT
name,123,xtype,typestat,xusertype,length,xprec,xscale,colid,xoffset,bitpos,reserved,colstat,cdefault,domain,number,colORDERBY,autoval,offset,collationid,language
FROM AisNew.dbo.syscolumns WHERE id=456

(2.4)用DTS單獨(dú)將t_voucher_b表導(dǎo)入新的DataBase
經(jīng)過以上操作,AIS20030529181217中t_voucher_b 表與原t_voucher表共用同一ID。
試試看可否執(zhí)行SELECT * FROM t_voucher_b 查詢 -
如果可以,那么t_voucher_b就一定繼承原t_voucher表中的全部數(shù)據(jù)。再用INSERT INTO AisNew.dbo.T_voucher FROM AIS20030529181217.dbo.t_voucher_b
或DTS 將t_voucher_b中的數(shù)據(jù)導(dǎo)入AisNew。
如果執(zhí)行SELECT * FROM t_voucher_b 查詢?nèi)匀粓?bào)錯,這張表徹底沒戲了。
(2.5) 其他”不可訪問的數(shù)據(jù)表”處理方式同上,重復(fù)(2.1)~(2.4) 步。

 

 
返回
客戶服務(wù) +more
上門服務(wù)
服務(wù)承諾
異地恢復(fù)
收費(fèi)標(biāo)準(zhǔn)
付款方式
疑難解答
服務(wù)特色 +more
·免費(fèi)檢測
·免費(fèi)提供3天備份
·專業(yè)工程師提供服務(wù)
·免費(fèi)清潔送修的介質(zhì)
·數(shù)據(jù)恢復(fù)前報(bào)價(jià),客戶確認(rèn)后工程師開始數(shù)據(jù)恢復(fù)
·數(shù)據(jù)恢復(fù)不成功不收費(fèi)
·與客戶簽訂保密協(xié)議,對客戶的數(shù)
 據(jù)嚴(yán)格保密,整個恢復(fù)過程不會對
 客戶的原盤有任何的寫操作,以確
 保原盤的數(shù)據(jù)完全

·免費(fèi)參觀恢復(fù)全過程

·工程師在線免費(fèi)咨詢

·專業(yè)工程師提供服務(wù)
服務(wù)器數(shù)據(jù)恢復(fù) 點(diǎn)擊這里給我發(fā)消

息
數(shù)據(jù)庫修復(fù)
點(diǎn)擊這里給我發(fā)

消息
硬盤數(shù)據(jù)恢復(fù)
點(diǎn)擊這里給我發(fā)消

息
主站蜘蛛池模板: 久久精品国产一区二区三区| 国产免费一区二区视频| 内射一区二区精品视频在线观看| 国产情侣一区二区| 国产伦精品一区二区三区免费下载 | 伊人久久精品无码av一区| 亚洲AV综合色区无码一区爱AV| 精品福利视频一区二区三区| 久久人妻无码一区二区| 岛国精品一区免费视频在线观看| 日本不卡一区二区三区| 成人中文字幕一区二区三区| 国产精品无码一区二区三区在| 精品国产亚洲一区二区在线观看 | 久久久久成人精品一区二区| 日本视频一区在线观看免费| 国产成人av一区二区三区不卡| 国产精品被窝福利一区 | 亚洲综合激情五月色一区| 国产一区二区三区国产精品| 亚洲线精品一区二区三区| 日韩av片无码一区二区不卡电影| 亚洲福利精品一区二区三区| 国产成人精品日本亚洲专一区| 一区二区高清在线| 亚洲AV成人一区二区三区观看 | 在线观看日韩一区| 日韩好片一区二区在线看| 国产精品亚洲一区二区三区久久| 久久亚洲国产精品一区二区| 国产在线观看精品一区二区三区91| 东京热无码一区二区三区av| 成人精品视频一区二区| 日韩电影一区二区三区| 国产乱码精品一区二区三区四川| 91精品福利一区二区三区野战| 一区二区三区四区在线观看视频| 日本无卡码一区二区三区| 亚洲性日韩精品国产一区二区| 亚洲一区二区三区免费视频| 中文字幕国产一区|