:SET XACT_ABORT各種用法及顯示結果![](/mis/simple_editor/emot/tips.jpg)
使用MSSQL事務回滾總結
1.默認為SET XACT_ABORT OFF 即遇到錯誤時回滾(真是暈,這不叫回滾,遇到錯誤當然不能執行了)所以干脆說默認回滾不起作用。
2.SET XACT_ABORT OFF
。。。
COMMIT TRAN
這時才是所謂真正的事務,遇到任何錯誤事務回滾
3.SET XACT_ABORT OFF
。。。
這時遇到錯誤時事務回滾,錯誤前的操作正常
另@@IDENTITY 系統產銷
==============================
理解 @@IDENTITY
@@IDENTITY 返回最后一個插入 IDENTITY 的值,這些操作包括:INSERT, SELECT INTO,或者 bulk copy。如果在給沒有 IDENTITY 列的其他表插入記錄,系統將其置為 null。如果有多行記錄插入到 IDENTITY 表中,@@IDENTITY 表示最后一個產生的值。如果觸發了某個觸發器,并且這個觸發器執行向另一個帶有 IDENTITY 列的表的插入操作,@@IDENTITY 將返回這個由觸發器產生的值。如果這個觸發器插入的表中不包含 IDENTITY 列,那么 @@IDENTITY 將為 null。如果插入操作失敗,@@IDENTITY 值依然會增加,所以 IDENTITY 不保證數據的連續性。
一、準備工作:
1、首先我們創建測試數據庫:
create database demo 2、創建數據表和測試數據:(這里注意外鍵控制)
use demo
CREATE TABLE student
(
stuid int NOT NULL PRIMARY KEY ,
stuname varchar ( 50 )
)
CREATE TABLE score
(
stuid int NOT NULL REFERENCES student(stuid),
score int
)
GO
![](/files/attmgn/2024/6/Ccoffee20240617155448443_0.jpg)
INSERT INTO student VALUES ( 101 , ' zhangsan ' )
INSERT INTO student VALUES ( 102 , ' wangwu ' )
INSERT INTO student VALUES ( 103 , ' lishi ' )
INSERT INTO student VALUES ( 104 , ' maliu ' )
![](/files/attmgn/2024/6/Ccoffee20240617155448443_0.jpg)
GO二、各種用法及輸出結果:
1、語句1:
use demo
![](/files/attmgn/2024/6/Ccoffee20240617155448443_0.jpg)
-- Invoking a run-time error
SET XACT_ABORT OFF
BEGIN TRAN
INSERT INTO score VALUES ( 101 , 90 )
INSERT INTO score VALUES ( 102 , 78 )
![](/files/attmgn/2024/6/Ccoffee20240617155449552_27.jpg)
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:
use demo
![](/files/attmgn/2024/6/Ccoffee20240617155448443_0.jpg)
-- 事務回滾
SET XACT_ABORT on
BEGIN TRAN
INSERT INTO score VALUES ( 101 , 90 )
INSERT INTO score VALUES ( 102 , 78 )
![](/files/attmgn/2024/6/Ccoffee20240617155449552_27.jpg)
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
![](/files/attmgn/2024/6/Ccoffee20240617155448443_0.jpg)
3、語句3:
use demo
![](/files/attmgn/2024/6/Ccoffee20240617155448443_0.jpg)
-- 事務在錯誤行終止,錯誤行回滾,錯誤行之前的不回滾
SET XACT_ABORT on
BEGIN
INSERT INTO score VALUES ( 101 , 90 )
INSERT INTO score VALUES ( 102 , 78 )
![](/files/attmgn/2024/6/Ccoffee20240617155449552_27.jpg)
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轉載于:https://www.cnblogs.com/wdx2008/archive/2007/12/19/1005196.html
該文章在 2024/6/17 15:54:55 編輯過