SET XACT_ABORT各种用法及显示结果

使用MSSQL事务回滚总结
 1.默认为SET XACT_ABORT OFF 即遇到错误时回滚(真是晕,这不叫回滚,遇到错误当然不能执行了)所以干脆说默认回滚不起作用。
 2.SET XACT_ABORT ON 
   。。。
  COMMIT TRAN
  这时才是所谓真正的事务,遇到任何错误事务回滚
 3.SET XACT_ABORT OFF
   。。。
   这时遇到错误时事务回滚,错误前的操作正常

  另@@IDENTITY 系统产销
==============================
理解 @@IDENTITY

@@IDENTITY 返回最后一个插入 IDENTITY 的值,这些操作包括:INSERT, SELECT INTO,或者 bulk copy。如果在给没有 IDENTITY 列的其他表插入记录,系统将其置为 null。如果有多行记录插入到 IDENTITY 表中,@@IDENTITY 表示最后一个产生的值。如果触发了某个触发器,并且这个触发器执行向另一个带有 IDENTITY 列的表的插入操作,@@IDENTITY 将返回这个由触发器产生的值。如果这个触发器插入的表中不包含 IDENTITY 列,那么 @@IDENTITY 将为 null。如果插入操作失败,@@IDENTITY 值依然会增加,所以 IDENTITY 不保证数据的连续性。



一、准备工作:

       1、首先我们创建测试数据库:

create   database  demo

    2、创建数据表和测试数据:(这里注意外键控制)

use  demo
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

二、各种用法及输出结果:

      1、语句1:

use  demo

-- Invoking a run-time error
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:

use  demo

-- 事务回滚
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:

use  demo

-- 事务在错误行终止,错误行回滚,错误行之前的不回滚
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
以上转载自: http://www.cnblogs.com/wdx2008/archive/2007/12/19/1005196.html
原文有一个错误,已经改正。。。。。。。。
另外附上自已写的一个存储过程
SQL-CODE/*
 *Author:董广祥
 *Date:2009/9/5
*/
create proc usp_Insert_sConfig
@IndCoope nvarchar(50),
@UserID nvarchar(20),
@UserName nvarchar(20),
@UserPwd nvarchar(50),
@GrpID int,
@Closed bit
as
if not exists(select ID from [dbo].[sConfig] where [IndCoope] = @IndCoope)
begin
 SET XACT_ABORT ON
 begin tran
  INSERT INTO [dbo].[sConfig] ([IndCoope])
  VALUES(@IndCoope)
  begin
   if not exists(select userid from sloguser where userid=@userid)
   begin
    INSERT INTO sLogUser (UserID, UserName, UserPwd, GrpID, Closed,Inc_Id)
    VALUES (@UserID,@UserName,@UserPwd,@GrpID,@Closed,SCOPE_IDENTITY())
   end
  end
 commit tran
end

你可能感兴趣的:(set)