事务:同生共死

    指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)–也就是由多个sql语句组成,必须作为一个整体执行

    这些sql语句作为一个整体一起向系统提交,要么都执行、要么都不执行

    语法步骤:

    开始事务:BEGIN TRANSACTION
    事务提交:COMMIT TRANSACTION
    事务回滚:ROLLBACK TRANSACTION
    判断某条语句执行是否出错:

    全局变量@@ERROR;

    @@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;

    —————————————-模拟转账——————————————
    declare @sumError int=0 —声明变量

    begin tran
    update bank set balance=balance-1000 where cId=’0001’
    set @sumError=@sumError+@@error
    update bank set balance=balance+1000 where cId=’0002’
    set @sumError=@sumError+@@error

    if (@sumError=0)
    commit tran —提交成功,提交事务
    else
    rollback tran —提交失败,回滚事务