源地址:http://www.cnblogs.com/rob0121/articles/2320932.html 点击进入

默认行为:默认为SET XACT_ABORT OFF,没有事务行为。

SET XACT_ABORT ON

SET XACT_ABORT ON分为两种:

  1、总体作为一个事务,整体提交或整体回滚,格式为:

SET XACT_ABORT ON
BEGIN TRAN
--要执行的语句
COMMIT TRAN
GO

2、每个语句作为一个事务,事务在错误行终止,错误行回滚,错误行之前的不回滚,格式为:

SET XACT_ABORT ON
BEGIN
--要执行的语句
END
GO

示例

--创建测试表
use MyDB
CREATE TABLE student
(
stuid int NOT NULL PRIMARY KEY,
stuname varchar(50)
)
CREATE TABLE score
(
stuid int NOT NULL REFERENCES student(stuid),
score int
)
GO --插入测试数据
INSERT INTO student VALUES (101,'zhangsan')
INSERT INTO student VALUES (102,'wangwu')
INSERT INTO student VALUES (103,'lishi')
INSERT INTO student VALUES (104,'maliu')
GO ---------------测试事务提交------------------
use MyDB
--只回滚错误行,语句还继续执行
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
/*
stuid score
----------- -----------
101 90
102 78
103 81
104 65 (4 row(s) affected)
*/ use MyDB
--事务终止并全部回滚
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
/*
stuid score
----------- -----------
(0 row(s) affected)
*/ use MyDB
--事务在错误行终止,错误行回滚,错误行之前的不回滚
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
/*
stuid score
----------- -----------
101 90
102 78
(2 row(s) affected)
*/

最新文章

  1. Delphi 实现数字转大写
  2. JS学习总结(新手)
  3. (转)myeclipse插件—SVN分支与合并详解【图】
  4. Xamarin开发Android笔记:使用ZXing进行连续扫描
  5. 腾讯用过的插件jQuery twentytwenty 效果对比
  6. Permissions 0664 for '/home/root/.ssh/id_rsa' are too open.
  7. [转载] 理解 rto
  8. Python学习第五天
  9. BZOJ 4036 [HAOI2015] Set 解题报告
  10. hadoop hdfs的java操作
  11. Android RelativeLayout 属性
  12. SQLCMD的用法,使用CMD 执行sql语句
  13. servlet 中字符集的处理
  14. elicpse之tomcat配置
  15. [您有新的未分配科技点]无旋treap:从好奇到入门(例题:bzoj3224 普通平衡树)
  16. UML序列图参考资料
  17. P2158 [SDOI2008] 仪仗队(欧拉函数模板)
  18. vue.js响应式原理解析与实现—实现v-model与{{}}指令
  19. 基于JAVA语言的selenium总结
  20. 第三章Div水平居中

热门文章

  1. Keil C51库函数原型列表
  2. TProcedure,TMethod,TNotifyEvent,TWndMethod的区别,并模拟点击按钮后发生的动作
  3. 【动态规划】XMU 1028 Game Boy Advance
  4. datagridview的数据源的操作
  5. 实Schur分解
  6. LinGo:投资问题——线性规划
  7. [TCO 2012 Round 3A Level3] CowsMooing (数论,中国剩余定理,同余方程)
  8. Be Sociable, Share!
  9. EMV/PBOC 解析(二) 卡片数据读取
  10. 用java具体代码实现分数(即有理数)四则运算