3 回答

TA貢獻(xiàn)1850條經(jīng)驗(yàn) 獲得超11個(gè)贊
SET XACT_ABORT ON
指示SQL Server回滾整個(gè)事務(wù)并在發(fā)生運(yùn)行時(shí)錯(cuò)誤時(shí)中止批處理。它涵蓋了在客戶(hù)端應(yīng)用程序上發(fā)生的命令超時(shí)而不是SQL Server本身(默認(rèn)XACT_ABORT OFF
設(shè)置未涵蓋)的情況。
由于查詢(xún)超時(shí)將使事務(wù)保持打開(kāi)狀態(tài),SET XACT_ABORT ON
因此建議在具有顯式事務(wù)的所有存儲(chǔ)過(guò)程中使用(除非您有特定的理由),因?yàn)閼?yīng)用程序在與開(kāi)放事務(wù)的連接上執(zhí)行工作的后果是災(zāi)難性的。
Dan Guzman博客上有一個(gè)很棒的概述,

TA貢獻(xiàn)1830條經(jīng)驗(yàn) 獲得超9個(gè)贊
引用MSDN:
當(dāng)SET XACT_ABORT為ON時(shí),如果Transact-SQL語(yǔ)句引發(fā)運(yùn)行時(shí)錯(cuò)誤,則終止并回滾整個(gè)事務(wù)。當(dāng)SET XACT_ABORT為OFF時(shí),在某些情況下,僅回滾引發(fā)錯(cuò)誤的Transact-SQL語(yǔ)句并繼續(xù)處理事務(wù)。
實(shí)際上,這意味著某些語(yǔ)句可能會(huì)失敗,使事務(wù)“部分完成”,并且調(diào)用者可能沒(méi)有出現(xiàn)此類(lèi)失敗的跡象。
一個(gè)簡(jiǎn)單的例子:
INSERT INTO t1 VALUES (1/0) INSERT INTO t2 VALUES (1/1) SELECT 'Everything is fine'
此代碼將在XACT_ABORT OFF時(shí)“成功”執(zhí)行,并在XACT_ABORT為ON時(shí)終止,錯(cuò)誤將終止(“INSERT INTO t2”將不會(huì)執(zhí)行,客戶(hù)端應(yīng)用程序?qū)⒁l(fā)異常)。
作為一種更靈活的方法,您可以在每個(gè)語(yǔ)句(舊學(xué)校)之后檢查@@ ERROR,或使用TRY ... CATCH塊(MSSQL2005 +)。我個(gè)人更喜歡在沒(méi)有理由進(jìn)行某些高級(jí)錯(cuò)誤處理時(shí)設(shè)置XACT_ABORT。
- 3 回答
- 0 關(guān)注
- 1834 瀏覽
添加回答
舉報(bào)