使用MSSQL事務(wù)回滾總結(jié)
1.默認(rèn)為SET XACT_ABORT OFF 即遇到錯(cuò)誤時(shí)回滾(真是暈,這不叫回滾,遇到錯(cuò)誤當(dāng)然不能執(zhí)行了)所以干脆說(shuō)默認(rèn)回滾不起作用。
2.SET XACT_ABORT OFF
。。。
COMMIT TRAN
這時(shí)才是所謂真正的事務(wù),遇到任何錯(cuò)誤事務(wù)回滾
3.SET XACT_ABORT OFF
。。。
這時(shí)遇到錯(cuò)誤時(shí)事務(wù)回滾,錯(cuò)誤前的操作正常
另@@IDENTITY 系統(tǒng)產(chǎn)銷(xiāo)
==============================
理解 @@IDENTITY
@@IDENTITY 返回最后一個(gè)插入 IDENTITY 的值,這些操作包括:INSERT, SELECT INTO,或者 bulk copy。如果在給沒(méi)有 IDENTITY 列的其他表插入記錄,系統(tǒng)將其置為 null。如果有多行記錄插入到 IDENTITY 表中,@@IDENTITY 表示最后一個(gè)產(chǎn)生的值。如果觸發(fā)了某個(gè)觸發(fā)器,并且這個(gè)觸發(fā)器執(zhí)行向另一個(gè)帶有 IDENTITY 列的表的插入操作,@@IDENTITY 將返回這個(gè)由觸發(fā)器產(chǎn)生的值。如果這個(gè)觸發(fā)器插入的表中不包含 IDENTITY 列,那么 @@IDENTITY 將為 null。如果插入操作失敗,@@IDENTITY 值依然會(huì)增加,所以 IDENTITY 不保證數(shù)據(jù)的連續(xù)性。
一、準(zhǔn)備工作:
1、首先我們創(chuàng)建測(cè)試數(shù)據(jù)庫(kù):
create database demo 2、創(chuàng)建數(shù)據(jù)表和測(cè)試數(shù)據(jù):(這里注意外鍵控制)
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

INSERT INTO student VALUES ( 101 , ' zhangsan ' )
INSERT INTO student VALUES ( 102 , ' wangwu ' )
INSERT INTO student VALUES ( 103 , ' lishi ' )
INSERT INTO student VALUES ( 104 , ' maliu ' )

GO二、各種用法及輸出結(jié)果:
1、語(yǔ)句1:
use demo

-- Invoking a run-time error
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:
use demo

-- 事務(wù)回滾
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:
use demo

-- 事務(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