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