Sqlserver中事务的写法

SET XACT_ABORT

指定当 Transact-SQL 语句产生运行时错误时,Microsoft? SQL Server? 是否自动回滚当前事务。分布式

语法

SET XACT_ABORT { ON | OFF }spa

注释

当 SET XACT_ABORT 为 ON 时,若是 Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时,只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。编译错误(如语法错误)不受 SET XACT_ABORT 的影响。orm

对于大多数 OLE DB 提供程序(包括 SQL Server),隐性或显式事务中的数据修改语句必须将 XACT_ABORT 设置为 ON。惟一不须要该选项的状况是提供程序支持嵌套事务时。有关更多信息,请参见分布式查询分布式事务blog

SET XACT_ABORT 的设置是在执行或运行时设置,而不是在分析时设置。事务

1.默认为SET XACT_ABORT OFF 即遇到错误时回滚(真是晕,这不叫回滚,遇到错误固然不能执行了)因此干脆说默认回滚不起做用。
 2.SET XACT_ABORT OFF 
   。。。
  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 不保证数据的连续性。
get

1、各类用法及输出结果:it

      一、语句1:编译

在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)use demo
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
--Invoking a run-time error
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
SET XACT_ABORT OFF
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
BEGIN TRAN
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score  VALUES (101,90)
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (102,78
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)    
INSERT INTO score VALUES (107,76 
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (103,81
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (104,65
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
COMMIT TRAN
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
goselect

      结果1:只回滚错误行,语句还继续执行。语法

在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)--select * from score
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
101    90
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
102    78
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
103    81
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
104    65

      二、语句2:

在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)use demo
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
--事务回滚
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
SET XACT_ABORT on
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
BEGIN TRAN
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score  VALUES (101,90)
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (102,78
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)    
INSERT INTO score VALUES (107,76 
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (103,81
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (104,65
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
COMMIT TRAN
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
go

      结果2:事务终止并所有回滚,结果为空。

在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)--select * from score
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)

      三、语句3:

在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)use demo
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
--事务在错误行终止,错误行回滚,错误行以前的不回滚
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
SET XACT_ABORT on
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
BEGIN
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
INSERT INTO score  VALUES (101,90)
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (102,78
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)    
INSERT INTO score VALUES (107,76 
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (103,81
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)     
INSERT INTO score VALUES (104,65
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
END
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
go

      结果3:出现这种是由于系统把每一个insert语句都当作是单独的事务,因此错误行之前的是不回滚的。

在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005)--select * from score
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
101    90
在存储过程当中编写正确的事务处理代码(SQL <wbr>Server <wbr>2000 <wbr>& <wbr>2005) 
102    78

相关文章
相关标签/搜索