SQL Server——事务

Posted asdyzh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server——事务相关的知识,希望对你有一定的参考价值。

事务:

保障流程的完整执行,就像银行取钱,先在你账上扣钱,然后存入别人的账上;但是从你账上扣完钱了,突然网断了,对方没有收到钱,那么此时你的钱也没了,别人的钱也没加上,事务为了防止此类情况的出现。

事务的基本格式:

begin tran --在流程开始的位置

 

if @@ERROR>0

begin  

rollback tran --回滚事务,到begin tran的位置,就当没发生过

end

else

begin  

commit tran --提交事务,都没问题,那么就一把进行提交

end

例题:购物车实例

 

begin tran --开启事务
declare @tran_error int; --存储错误
set @tran_error = 0; --默认没有错误

update Fruit set Numbers = Numbers-1 where Ids=‘k002‘
set @tran_error = @tran_error + @@ERROR;
update Login set Account=Account-1 where UserName=‘wangwu‘
set @tran_error = @tran_error + @@ERROR;
insert into Orders values(‘d002‘,‘wangwu‘,‘2016-8-7‘)
set @tran_error = @tran_error + @@ERROR;
insert into OrderDetails values(‘d002‘,‘k002‘,10)
set @tran_error = @tran_error + @@ERROR;


if @tran_error>0
begin
rollback tran --回滚事务,到begin tran的位置,就当没发生过
end
else
begin
commit tran --提交事务,都没问题,那么就一把进行提交
end

 

注:例题里面用到了SQL Server中一个自带的变量——ERROR,表示若上面的语句正确,@@ERROR=0;相反不等于0.


















以上是关于SQL Server——事务的主要内容,如果未能解决你的问题,请参考以下文章

sql server运行中,是不是能删除主数据库事务日志文件

sql server 2008 的事务日志文件存储数据库的啥情况

怎样读sql server 2008 事务日志

SQL Server 事务异常和游标

SQL Server 的事务和锁

sql server 2000日志有啥用处