SQL|SQL SERVER提交事务回滚机制
1、回滚语句1:
SET XACT_ABORT OFF
BEGIN TRAN
INSERT INTO scoreVALUES (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 scoreVALUES (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|SQL SERVER提交事务回滚机制】 到此这篇关于SQL SERVER提交事务回滚机制的文章就介绍到这了,更多相关SQL SERVER事务回滚内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- gitlab|gitlab 通过备份还原 admin/runner 500 Internal Server Error
- py连接mysql
- 2019-01-18Mysql中主机名的问题
- MySql数据库备份与恢复
- mysql|InnoDB数据页结构
- 数据库|SQL行转列方式优化查询性能实践
- mysql中视图事务索引与权限管理
- MYSQL主从同步的实现
- Hadoop|Hadoop MapReduce Job提交后的交互日志
- MySQL数据库的基本操作