zoukankan      html  css  js  c++  java
  • 什么叫事务

     什么叫事务? 这些就是数据库特有的术语了。懒虫在这里口头解释:就是把多件事情当做一件事情来处理。也就是大家同在一条船上,要活一起活,要over一起over !

       我为什么要使用事务? 俺这里再举个很俗很俗的例子:

         俺到银行存钱,于是有这么几个步骤:
           1、把钱交给工作人员;2、工作人员填单;3、将单子给我签字;4、工作人员确认并输入电脑。

       要是,要是我把钱交给工作人员之后,进行到3我签字了。那哥们突然心脏病发作,over掉了,那,我的钱还没有输入电脑,但我却交了钱又签字确认了,而并没有其他任何记录。我岂不是要亏死了???我的血汗钱啊!赶紧退给我!!

       于是,在数据库里产生了这么一个术语:事务(Transaction),也就是要么成功,要么失败,并恢复原状。
      
       还是写程序把:

       Create Proc sp我去存款(@M Money , @iOperator Int)
       As
       Begin
        Declare @i int

        Begin Tran           --激活事务
         Exec @i=sp交钱 @m,@iOperator
         if @i<>0           --这里一般用系统错误号 @@Error。 我这里为了举例子没有用到。需要根据实际情况。
         begin
          Rollback Tran                   --回滚事务
          RaisError ('银行的窗口太少了,我懒得排队,不交了!:( ', 16, 1) with Log --记录日志
          Return -1                     --返回错误号
         end

         Exec @i=sp填单 @m,@iOperator
         if @i<>0
         begin
          Rollback Tran                   --回滚事务
          RaisError ('银行的哥们打印机出了点毛病,打印不出单子来,把钱退回来给我吧??', 16, 1) with Log
          Return -2                     
         end

         Exec @i=sp签字 @m
         if @i<>0
         begin
          Rollback Tran                   --回滚事务
          RaisError ('我 靠?什么烂银行,换了3支笔都写不出水来!!老子不存了!!不签!', 16, 1) with Log 
          Return -3                     
         end

         Exec @i=sp输入电脑 @m,@iOperator
         if @i<>0
         begin
          Rollback Tran                   --回滚事务
          RaisError ('什么意思?磁盘空间已满?好了好了,把钱给我,我到旁边的这家银行!', 16, 1) with Log 
          Return -4                     
         end
     
        Commit Tran        --提交事务
        Return 0
      End
     

           ----------------------------------------------------------------------
           以上是伪代码,模拟我去存款的过程。
  • 相关阅读:
    vue从详情页回到列表页,停留在之前的tab上
    vue-touch监听手指左滑右滑事件
    vue事件代理
    vue通过ref获取组件渲染后的dom(this.$refs.xxxRef.$el)
    vue水印-第二种方法:通过指令
    # 有时候代码超时
    # 今天的leetcode1268又用上了二分搜索。
    # linux命令小常识
    # 大家好
    今天尝试配置maven的时候
  • 原文地址:https://www.cnblogs.com/winner/p/633297.html
Copyright © 2011-2022 走看看