文章目录
- 什么是事务
- 事务模式的分类
- 事务的使用示例
什么是事务
事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,如果任何一个语句操作失败那么整个操作就被失败,进而回滚到操作前状态,或者是上个节点。为了确保要么执行,要么不执行,就可以使用事务。要将一组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。
事务模式的分类
SQL Server 以下列事务模式运行:
自动提交事务
每条单独的语句都是一个事务。
显式事务
每个事务均以 BEGIN TRANSACTION 语句显式开始,以 COMMIT 或 ROLLBACK 语句显式结束。
隐式事务
在前一个事务完成时新事务隐式启动,但每个事务仍以 COMMIT 或 ROLLBACK 语句显式完成。
批处理级事务
只能应用于多个活动结果集 (MARS),在 MARS 会话中启动的 Transact-SQL 显式或隐式事务变为批处理级事务。 当批处理完成时没有提交或回滚的批处理级事务自动由 SQL Server 进行回滚。
事务的使用示例
我们以一张表为例演示事务的使用。
给Customer表的Remain字段添加一个约束。
--张三给--李四转账 200
select*from Customer
go
--定义一个变量,记录错误数
declare @error_nums int
set @error_nums=0
--开始事务
begin transaction tran_change
begin try
update customer set Remain=Remain-200 where id=1
set @error_nums=@error_nums+@@error
update customer set Remain=Remain+200 where id=2
set @error_nums=@error_nums+@@error
end try
begin catch
set @error_nums=@error_nums+1
print'错误异常:'+convert(varchar,error_number())+',错误信息'+error_message()
end catch
if(@error_nums>0) --表示前面有错
rollback transaction tran_change --回滚事务
else
commit transaction tran_change --执行事务
select*from Customer
--注:
--@@ERROR:当前一个语句遇到错误,则返回错误号,否则返回0。
--需要注意的是@ERROR在每一条语句执行后会被立刻重置,
--因此应该在要验证的语句执行后检查数值或者是将它保存到局部变量中以备将来使用。
--没使用事务,对的就执行,错误的就不执行