指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)--也就是由多个sql语句组成,必须作为一个整体执行
这些sql语句作为一个整体一起向系统提交,要么都执行、要么都不执行
语法步骤:
开始事务:BEGIN TRANSACTION
事务提交:COMMIT TRANSACTION
事务回滚:ROLLBACK TRANSACTION
判断某条语句执行是否出错:
全局变量@@ERROR;
@@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;
例:SET @errorSum=@errorSum+@@error
如,借钱问题:
假定钱从A转到B,至少需要两步:
- A的资金减少
- 然后B的资金相应增加
CREATE TABLE bank
(
uName CHAR(10), --姓名
uMoney MONEY --当前余额
)
GO
ALTER TABLE bank
ADD CONSTRAINT CK_nowMoney
CHECK(uMoney>=1)
GO
INSERT INTO bank(uName, uMoney)
VALUES('家宝',1000)
INSERT INTO bank(uName, uMoney)
VALUES('奥巴马',1)
例题:
1.表category
select * from category
2.建立约束c_name名字不小于2个字
3.执行下列语句报错
update category set c_name = '1' where c_id =1
4.写事务
declare @errNum int
set @errNum=0
begin transaction --先开始事务
update category set c_name = '1' where c_id =1
set @errNum =@errNum +@@error
delete from Category where c_id =120
set @errNum =@errNum +@@error
if @errNum=0
begin
commit transaction
print 'OK!'
end
else
begin
rollback transaction
print 'ERROR!'
end
select * from category
执行结果:
结果:c_id=120也没有删除