zoukankan      html  css  js  c++  java
  • 事务

    事务:

    保障流程的完整执行

    就像银行取钱,先在你账上扣钱,然后存入别人的账上,

    但是从你账上扣完钱了,突然断网了,对方没有收到钱,那么此时你的钱也没有了,,

    别人的钱也没加上,为了防止此类情况的出现,就用事务。

    begin tran--在流程开始的位置

    if @@ERROR>0

    begin

        rollback tran---回滚事务,到begin tran的位置,就当没发生过

    end

    else

    begin

         commit tran  --提交事务,都没问题。那么就进行提交

    end

    购物实例:

    begin tran  --开启事务

    declare @tran_error int  --存储错误

    set @tran_error=0  --默认没有错误

    update fruit set numbers=numbers-1 where ids='k002'--fruit表中K002库存-1

    set @tran_error=@tran_error+@@ERROR  --如果等于0,以上语句没错,如果不等于0,以上语句有错

    update login set account=account-1 where username='wangwu'--login表中account(账户余额)-1

    set @tran_error=@tran_error+@@ERROR

    insert into orders values('d002','wangwu','2016-8-7')  --在orders表中添加一个订单

    set @tran_error=@tean_error+@@ERROR

    insert into orderdetails values('d002','k002','10')  --在订单详情表中添加一条数据

    set @tran_error=@tean_error+@@ERROR

    if @tran_error>0

    begin

        rollback tran

    end

    else

    begin

       commit tran

    end

  • 相关阅读:
    2018.4.5课堂笔记
    黑白染色——封锁阳光大学
    末日游戏——杨辉三角+搜索
    dilworth定理+属性排序(木棍加工)
    伯努利错装信封问题
    zhx'code1
    字符串-----KMP竟然是18禁
    Presto Event Listener开发
    Presto安装完成之后需要做的
    Apache Calcite 论文学习笔记
  • 原文地址:https://www.cnblogs.com/yp11/p/5747509.html
Copyright © 2011-2022 走看看