1、回滾語(yǔ)句1:
SET XACT_ABORT OFF
BEGIN TRAN
INSERT INTO score VALUES (101,90)
INSERT INTO score VALUES (102,78)
INSERT INTO score VALUES (107,76) /**//* Foreign Key Error */
INSERT INTO score VALUES (103,81)
INSERT INTO score VALUES (104,65)
COMMIT TRAN
go
結(jié)果1:只回滾錯(cuò)誤行,語(yǔ)句還繼續(xù)執(zhí)行。
–select * from score
101 90
102 78
103 81
104 65
2、回滾語(yǔ)句2:
SET XACT_ABORT on
BEGIN TRAN
INSERT INTO score VALUES (101,90)
INSERT INTO score VALUES (102,78)
INSERT INTO score VALUES (107,76) /**//* Foreign Key Error */
INSERT INTO score VALUES (103,81)
INSERT INTO score VALUES (104,65)
COMMIT TRAN
go
結(jié)果2:事務(wù)終止并全部回滾,結(jié)果為空。
–select * from score
3、回滾語(yǔ)句3:
事務(wù)在錯(cuò)誤行終止,錯(cuò)誤行回滾,錯(cuò)誤行之前的不回滾
SET XACT_ABORT on
BEGIN
INSERT INTO score VALUES (101,90)
INSERT INTO score VALUES (102,78)
INSERT INTO score VALUES (107,76) /**//* Foreign Key Error */
INSERT INTO score VALUES (103,81)
INSERT INTO score VALUES (104,65)
END
go
結(jié)果3:出現(xiàn)這種是因?yàn)橄到y(tǒng)把每個(gè)insert語(yǔ)句都看成是單獨(dú)的事務(wù),所以錯(cuò)誤行以前的是不回滾的。
–select * from score
101 90
102 78
到此這篇關(guān)于SQL SERVER提交事務(wù)回滾機(jī)制的文章就介紹到這了,更多相關(guān)SQL SERVER事務(wù)回滾內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- SQLServer2008提示評(píng)估期已過(guò)解決方案
- SQLServer2019 數(shù)據(jù)庫(kù)的基本使用之圖形化界面操作的實(shí)現(xiàn)
- SQLServer2019 數(shù)據(jù)庫(kù)環(huán)境搭建與使用的實(shí)現(xiàn)
- SQLServer 日期函數(shù)大全(小結(jié))
- SQLServer2019配置端口號(hào)的實(shí)現(xiàn)
- sqlserver主鍵自增的實(shí)現(xiàn)示例