暧昧:专注于J2ee和asp.net开发.努力奋发,学习java与.net最新技术开发研究(www.ufohack.com)

黑马程序员–学习日志之事务

 

———————- 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/

 

标签:
分类:
asp.net | 发布:admin | 评论:0 条 | 发表时间:2012-01-1 04:46
引用:点击这里获取该日志的TrackBack引用地址
上一篇:
下一篇:

发表评论

*

* 绝不会泄露


Design By pakelab | Power By 暧昧博客