一、为什么需要事务
1、如,借钱问题:
假定钱从A转到B,至少需要两步:
A的资金减少;
然后B的资金相应增加。
数据:
CREATE TABLE bank
(uName CHAR(10), --姓名uMoney MONEY --当前余额
)
GO
ALTER TABLE bankADD CONSTRAINT CK_nowMoney CHECK(uMoney>=1)
GO
INSERT INTO bank(uName, uMoney)VALUES(‘特朗普',1000)
INSERT INTO bank(uName, uMoney)VALUES(‘奥巴马',1)
这样转账,会否出问题?
UPDATE bank SET uMoney=uMoney-1000 WHERE uName='特朗普‘ @@error
UPDATE bank SET uMoney=uMoney+1000WHERE uName='奥巴马‘
@@error
--查看结果。
SELECT * FROM bank
二、什么是事务(Transaction)
2、指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)--也就是由多个sql语句组成,必须作为一个整体执行。
3、这些sql语句作为一个整体一起向系统提交,要么都执行、要么都不执行。
4、语法步骤:
- 开始事务:BEGIN TRANSACTION
- 事务提交:COMMIT TRANSACTION
- 事务回滚:ROLLBACK TRANSACTION
5、判断某条语句执行是否出错: 全局变量@@ERROR;
@@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;
例:SET @errorSum=@errorSum+@@error
6、例:
BEGIN TRANSACTION
/*--定义变量,用于累计事务执行过程中的错误--*/
DECLARE @errorSum INT
SET @errorSum=0 --初始化为0,即无错误
/*--转账:张三的账户少1000元,李四的账户多1000元*/
UPDATE bank SET currentMoney=currentMoney-1000WHERE customerName='张三'
SET @errorSum=@errorSum+@@error --累计是否有错误
UPDATE bank SET currentMoney=currentMoney+1000WHERE customerName='李四'
SET @errorSum=@errorSum+@@error --累计是否有错误
If @errorSum>0
Beginrollback transactionselect ‘失败’
End
Else
Begincommit transactionselect ‘成功’
End