SQL SERVER事务提交回滚

打印 上一主题 下一主题

主题 659|帖子 659|积分 1977

1、回滚语句1:
SET XACT_ABORT OFF
BEGIN TRAN
  1. INSERT INTO score   VALUES (101,90)
  2. INSERT INTO score VALUES (102,78)
  3.     INSERT INTO score VALUES (107,76) /**//* Foreign Key Error */
  4. INSERT INTO score VALUES (103,81)
  5. INSERT INTO score VALUES (104,65)
复制代码
COMMIT TRAN
go
  1.   结果1:只回滚错误行,语句还继续执行。
复制代码
–select * from score
101 90
102 78
103 81
104 65
2、回滚语句2:
SET XACT_ABORT on
BEGIN TRAN
  1. INSERT INTO score   VALUES (101,90)
  2. INSERT INTO score VALUES (102,78)
  3.     INSERT INTO score VALUES (107,76) /**//* Foreign Key Error */
  4. INSERT INTO score VALUES (103,81)
  5. 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)
  1. INSERT INTO score VALUES (102,78)
  2.     INSERT INTO score VALUES (107,76) /**//* Foreign Key Error */
  3. INSERT INTO score VALUES (103,81)
  4. INSERT INTO score VALUES (104,65)
复制代码
END
go
  1.   结果3:出现这种是因为系统把每个insert语句都看成是单独的事务,所以错误行以前的是不回滚的。
复制代码
–select * from score
101 90
102 78

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

玛卡巴卡的卡巴卡玛

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表