zoukankan      html  css  js  c++  java
  • SQL Server 的事务处理的两种格式

    一种是用TRY...CATCH语句,例:

    ---这仅仅是实例
    create procedure [dbo].[MyTryTran] --创建存储过程
    --
    @toID int, --接收转账的账户
    --
    @fromID int , --转出自己的账户
    --
    @momeys money --转账的金额
    as
    begin transaction
    BEGIN TRY
         select 1/0
         insert into t_Sex (FID,FSex) values (3,'na')
    commit transaction
    END TRY
    BEGIN CATCH
    begin
    rollback transaction
    end
    END CATCH

    第二种是捕捉error错误

    create procedure [dbo].[MyTran] --创建存储过程,定义几个变量
    --@toID int,    --接收转账的账户
    --@fromID int ,  --转出自己的账户
    --@momeys money --转账的金额
    as 
    begin transaction
    	declare @errorSum int    --定义变量,用于累计事务执行过程中的错误
    	set @errorSum=0
          select 1/0
    	set @errorSum=@errorSum+@@error --累计是否有错误
    
    	insert into t_Sex (FID,FSex) values ('3','n')
    	set @errorSum=@errorSum+@@error    --累计是否有错误
    if @errorSum>0
        begin        
            rollback transaction
        end
    else
        begin        
            commit transaction
        end
    

    有一种错误的方式,请看:

    alter procedure [dbo].[MyErrorTran] 
    as 
    begin transaction	
    	select 1/0
    	insert into t_Sex (FID,FSex) values ('3','n')
    	commit transaction
    if @@error>0            
    	rollback transaction
    
    --事实上不管用,因为@@error只对上一条语句管用,所以在本例中尽管发生了错误,但还是不会回滚

     
     
  • 相关阅读:
    python uiautomator2 安装
    python xml
    python实现串口发送接收数据
    linux下查看nginx配置文件地址
    laravel学习笔记(二)
    mac下/usr/local/bin No such file or directory问题解决
    -bash: mysql: command not found 之 MAC
    mac下安装apache+php+mysql
    phpstorm设置代码块快捷方式
    git笔记
  • 原文地址:https://www.cnblogs.com/eyye/p/2211258.html
Copyright © 2011-2022 走看看