———————- Windows Phone 7手机开发、.Net培训、期待与您交流! ———————-
事务,为什么需要事务,
假定钱从A转到B,至少需要两步:
A的资金减少
然后B的资金相应增加
update bank set balance=balance-1000 where cid=’0001′
update bank set balance=balance + 1000 where cid=’0002′
–查看结果。
SELECT * FROM bank
代码如下
–事务
create table bank
(
cId char(4) primary key,
balance money, –余额
)
alter table bank
add constraint CH_balance check(balance >=10)
go
–delete from bank
insert into bank values(’0001′,1000)
insert into bank values(’0002′,10)
go
update bank set balance=balance-1000 where cid=’0001′
update bank set balance=balance + 1000 where cid=’0002′
什么是事务
事务:同生共死
指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)–也就是由多个sql语句组成,必须作为一个整体执行
这些sql语句作为一个整体一起向系统提交,要么都执行、要么都不执行
语法步骤:
开始事务:BEGIN TRANSACTION
事务提交:COMMIT TRANSACTION
事务回滚:ROLLBACK TRANSACTION
判断某条语句执行是否出错:
全局变量@@ERROR;
@@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;
例:SET @errorSum=@errorSum+@@error
事物的代码
select * from bank
–使用事务
begin transaction
declare @error int
set @error = 0
update bank set balance=balance-1000 where cid=’0001′
set @error = @error + @@error
update bank set balance=balance + 1000 where cid=’0002′
set @error = @error + @@error
if @error != 0
rollback transaction
else
commit transaction
go
select * from bank
———————- Windows Phone 7手机开发、.Net培训、期待与您交流! ———————-
详细请查看:http://net.itheima.com/