欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SQL SERVER提交事务回滚机制

程序员文章站 2022-07-05 09:41:35
1、回滚语句1:set xact_abort offbegin traninsert into score values (101,90)insert into score values (102...

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事务回滚内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!