• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

sqlserver事务与回滚

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论

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

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

begin tran t1 -启动一个事务

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

来1源gaodai#ma#com搞*代#码1网insert into [water].[dbo].[ErrorInf]([ID],ErrorMessage,[Description])
Values(1,test1,test1)

commit tran t1 -提交事务

功能:实现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就可以了

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

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

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

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

后来发现sql2005支持try

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, @ErrSeverity, 1)
END CATCH

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

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

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


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:sqlserver事务与回滚

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址