• 售前

  • 售后

热门帖子
入门百科

SQL SERVER提交变乱回滚机制

[复制链接]
心随674 显示全部楼层 发表于 2021-8-14 14:26:25 |阅读模式 打印 上一主题 下一主题
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. <span style="background-color: initial;">  结果1:只回滚错误行,语句还继续执行。</span>
复制代码
–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. <span style="background-color: initial;">  结果3:出现这种是因为系统把每个insert语句都看成是单独的事务,所以错误行以前的是不回滚的。</span>
复制代码
–select * from score
101 90
102 78
到此这篇关于SQL SERVER提交事务回滚机制的文章就先容到这了,更多相关SQL SERVER事务回滚内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望各人以后多多支持脚本之家!

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作