sqlserver事务与回滚

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-07 15:17:40
オリジナル
1604 人が閲覧しました

set XACT_ABORT ON -- -如果不设置该项为ON,在sql中默认为OFF,那么只只回滚产生错误的Transact-SQL语句;设为ON,回滚整个事务 begin tran t1 -- -启动一个事务 update [ water ] . [ dbo ] . [ ErrorInf ] set ErrorMessage = ' test ' where ID = 6 inse

sqlserver事务与回滚

set XACT_ABORT ON   ---如果不设置该项为ON,在sql中默认为OFF,那么只只回滚产生错误的 Transact-SQL 语句;设为ON,回滚整个事务

begin tran t1 ---启动一个事务

update [water].[dbo].[ErrorInf]
set ErrorMessage='test'
where ID=6

insert into [water].[dbo].[ErrorInf]([ID],ErrorMessage,[Description])
Values(1,'test1','test1')

commit tran t1  ---提交事务

sqlserver事务与回滚

功能:实现begin tran 和commit tran之间的语句,任一如果出现错误,所有都不执

 

事务不是有错就回滚的,在不写rollback的情况下,并不是什么错误都会回滚事务,有时回滚当前语句,有时回滚整个事务

如例

begin tran 
insert into dbo.area values('1111')
insert into dbo.area values('2222')
select 1/0
insert into dbo.area values('333')
commit

 

像这样,就算中间有错,也不会回滚,结果会成功添加三条记录

但有人说,比如重大错误,这事务也会所有回滚,只是我无法重现重大错误罢了

普通错误如果想回滚整个事务,只要加个set XACT_ABORT on就可以了

sqlserver事务与回滚

set XACT_ABORT on

begin tran

insert into dbo.area values('1111')
insert into dbo.area values('2222')
select 1/0
insert into dbo.area values('333')

commit

sqlserver事务与回滚

 

 

但也有人写一堆@@error,如

sqlserver事务与回滚

begin tran 

insert into dbo.area values('1111')
if @@error>0
  rollback

insert into dbo.area values('2222')
if @@error>0
  rollback

select 1/0
if @@error>0
  rollback

insert into dbo.area values('333')
if @@error>0
  rollback

commit

sqlserver事务与回滚

 

当然也行,不过写起来太麻烦了.

后来发现sql2005支持try

sqlserver事务与回滚

BEGIN TRY
   
BEGIN TRANSACTION
     
insert into dbo.area values('1111')
    
insert into dbo.area values('2222')
    
select 1/0
    
insert into dbo.area values('333')
   
COMMIT
END TRY
BEGIN CATCH
   
IF @@TRANCOUNT > 0
     
ROLLBACK

  
DECLARE @ErrMsg nvarchar(4000), @ErrSeverity int
  
SELECT @ErrMsg = ERROR_MESSAGE(),
         
@ErrSeverity = ERROR_SEVERITY()

  
RAISERROR(@ErrMsg@ErrSeverity1)
END CATCH

sqlserver事务与回滚

 

http://www.cnblogs.com/jay-c/articles/1501002.html

 

事务回滚会使数据库回复到事务开始时的状态

出现下述情况时,事务会回滚
1.手工用rollback   tran回滚
2.设置了set   xact_abort   on后,出错时会自动回滚
3.事务提交前,电脑出现故障,或者sql意外终止,事务会自动回滚

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート