1、回滾語句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
結果1:只回滾錯誤行,語句還繼續執行。
–select * from score
101 90
102 78
103 81
104 65
2、回滾語句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
結果2:事務終止并全部回滾,結果為空。
–select * from score
3、回滾語句3:
事務在錯誤行終止,錯誤行回滾,錯誤行之前的不回滾
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
結果3:出現這種是因為系統把每個insert語句都看成是單獨的事務,所以錯誤行以前的是不回滾的。
–select * from score
101 90
102 78
到此這篇關于SQL SERVER提交事務回滾機制的文章就介紹到這了,更多相關SQL SERVER事務回滾內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- SQLServer2008提示評估期已過解決方案
- SQLServer2019 數據庫的基本使用之圖形化界面操作的實現
- SQLServer2019 數據庫環境搭建與使用的實現
- SQLServer 日期函數大全(小結)
- SQLServer2019配置端口號的實現
- sqlserver主鍵自增的實現示例