含义:事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,如果任何一个语句操作失败那么整个操作就被失败,进而回滚到操作前状态,或者是上个节点。为了确保要么执行,要么不执行,就可以使用事务。要将一组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。
优点:原子性、一致性、持久性通过数据库日志实现。
批处理数据库操作。
保证数据库级联操作的正确性。
缺点:执行较慢。
需要较多的磁盘空间保存事务日志。
执行更新需要内存较多。
具体事例:
一个表Customer
代码实现一个转账的功能:
--定义一个变量,记录错误数
declare @error_nums int
set @error_nums=0
--开始事务
begin transaction tran_change
begin try
update Customer set Remain=(Remain-@Remain) where id=@idOut
set @error_nums=@error_nums+@@ERROR
update Customer set Remain=(Remain+@Remain) where id=@idIn
set @error_nums=@error_nums+@@ERROR
end try
begin catch
set @error_nums=@error_nums+1
print '错误异常:'+convert(varchar,error_number())+'错误信息'+</