使用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

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
二、各种用法及输出结果:
1、语句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
结果1:只回滚错误行,语句还继续执行。
--
select * from score
101
90
102
78
103
81
104
65
2、语句2:
use
demo

--
事务回滚
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:
use
demo

--
事务在错误行终止,错误行回滚,错误行之前的不回滚
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