一個(gè)奇怪的U8帳套備份失敗問題

客戶反饋U8帳套很長時(shí)間沒有進(jìn)行自動(dòng)備份了。我們遠(yuǎn)程檢查的時(shí)候,嘗試手動(dòng)備份帳套。但是系統(tǒng)顯示以下錯(cuò)誤:

工作流數(shù)據(jù)處理失敗,SQL SERVER檢測到邏輯一致性I/O錯(cuò)誤。

第一感覺是數(shù)據(jù)庫出問題了,使用DBCCDBCHECK檢查數(shù)據(jù)庫,也顯示【邏輯一致性I/O錯(cuò)誤】。
使用SQL Server Profiler跟蹤帳套備份,抓取相關(guān)的SQL腳本,定位到出錯(cuò)的腳本為

if exists (select * from sysobjects where id = object_id(N'[Table_TemplateKind]')and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[Table_TemplateKind];

查看該表:SELECT* FROM Table_TemplateKin時(shí)報(bào)錯(cuò),判斷該表INDEX損壞。使用以下步驟修復(fù)數(shù)據(jù)庫表。

1.執(zhí)行SQL語句,斷開除自己外所有用戶連接:

declare @sql varchar(100)
while 1=1
begin
select top 1 @sql = 'kill '+cast(spid as varchar(3))
from master..sysprocesses
where spid > 50 and spid <> @@spid and dbid=db_id(' UFDATA_012_2014')
if @@rowcount = 0
break
exec(@sql)
end

2.在單用戶模式下,修復(fù)數(shù)據(jù)庫:

USE MASTER
GO
sp_dboption 'UFDATA_012_2014', 'single user', 'true'
GO
DBCC CHECKDB(' UFDATA_012_2014', REPAIR_ALLOW_DATA_LOSS)
GO
USE UFDATA_012_2014
GO
exec sp_msforeachtable 'DBCC CHECKTABLE(''?'',REPAIR_REBUILD)'
GO
sp_dboption ' UFDATA_012_2014', 'single user', 'false'
GO

3.重建該表索引:

DBCC DBREINDEX(Table_TemplateKind,'',90)

重新備份帳套成功。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容