回代怎么写

事务是访问并可能更新数据库中各种数据项的一个程序执行单元,也是SQL Server软件其中的一种功能。事务通常由高级数据库操纵语言或编程语言书写的用户程序的执行所引起,并用形如begin transaction和end transaction语句(或函数调用)来界定。事务由事务开始(begin transaction)和事务结束。(end transaction)之间执行的全体操作组成

回代怎么写

sql server事务回滚代码怎么写

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,[Deion])

Values(1,'test1','test1')

commit tran t1 ---提交事务

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

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

如例

begin tran

insert into dbo.area values('1111')

insert into dbo.area values('2222')

sel原由网ect 1/0

insert in原由网to dbo.area values('333')

commit

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

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

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

sql事务处理几种方法介绍:

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

BEGIN TRANSACTION--开始事务

DECLARE @errorSun INT --定义错误计数器

SET @errorSuwww.58yuanyou.comn=0 --没错为0

UPDATE a SYosQjET id=232 WHERE a=1 --事务操作SQL语句

SET @errorSun=@errorSun+@@ERROR --累计是否有错

UPDATE aa SET id=2 WHERE a=1 --事务操作SQL语句,可以是存储过程

SET @errorSun=@errorSun+@@ERROR --累计是否有错

IF @errorSun<>0

BEGIN

PRINT '有错误,回滚'

ROLLBACK TRANSACTION--事务回滚语句

END

ELSE

BEGIN

PRINT '成功,提交'

COMMIT TRANSACTION--事务提交语句

来实现事务的处理。

内容版权声明:除非注明原创否则皆为转载,再次转载请注明出处。

文章标题: 回代怎么写

文章地址: www.58yuanyou.com/jiqiao/134311.html

相关推荐