加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

Sqlserver中事务的写法

发布时间:2020-12-12 12:53:47 所属栏目:MsSql教程 来源:网络整理
导读:SET XACT_ABORT 指定当 Transact-SQL 语句产生运行时错误时,Microsoft? SQL Server? 是否自动回滚当前事务。 语法 SET XACT_ABORT { ON | OFF } 注释 当 SET XACT_ABORT 为 ON 时,如果 Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时

SET XACT_ABORT

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

语法

SET XACT_ABORT { ON | OFF }

注释

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

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

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

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

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

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

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

??????1、语句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)

?
OFF

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?
BEGIN

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?????
INSERTINTO?score??VALUES?(101,90)

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?????
?score?10278)?

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

????
10776)??

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?????
10381)?

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?????
10465)?

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?
go

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

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

select?*?from?score

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?
????

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

?
65

??????2、语句2:

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

事务回滚on??????结果2:事务终止并全部回滚,结果为空。

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)


在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

??????3、语句3:

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

事务在错误行终止,错误行回滚,错误行之前的不回滚END??????结果3:出现这种是因为系统把每个insert语句都看成是单独的事务,所以错误行以前的是不回滚的。

在存储过程中编写正确的事务处理代码(SQL?<wbr>Server?<wbr>2000?<wbr>&?<wbr>2005)

78

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读