SQLServer 存储过程嵌套事务处理

php中文网
发布: 2016-06-07 15:44:29
原创
1698人浏览过

某个存储过程可能被单独调用,也可能由其他存储过程嵌套调用,则可能会发生嵌套事务的情形。 下面是一种解决存储过程嵌套调用的通用代码,在不能确定存储过程是否可能被其他存储过程调用的情况下,建议每个存储过程都按照这个模板建立 create proc proc_exam

某个存储过程可能被单独调用,也可能由其他存储过程嵌套调用,则可能会发生嵌套事务的情形。

下面是一种解决存储过程嵌套调用的通用代码,在不能确定存储过程是否可能被其他存储过程调用的情况下,建议每个存储过程都按照这个模板建立

<span><span>create</span> <span>proc</span><span> proc_example
</span><span>as</span> 
<span>begin</span> 
    <span>--</span><span>声明变量,存放当前已开启的事务数</span>
    <span>declare</span> <span>@exist_trancount</span> <span>int</span>
    <span>select</span> <span>@exist_trancount</span> <span>=</span> <span>@@trancount</span>

    <span>if</span> <span>@exist_trancount</span> <span>></span> <span>0</span>
        <span>--</span><span>创建事务保存点</span>
        <span>save</span> <span>transaction</span><span> tran_proc
    </span><span>else</span>
        <span>--</span><span>开启新事务</span>
        <span>begin</span> <span>transaction</span><span> tran_proc
        
    </span><span>/*</span><span>
        存储过程业务处理代码
        &middot;&middot;&middot;&middot;&middot;&middot;&middot;&middot;&middot;
    </span><span>*/</span>
    <span>if</span> <span>@@error</span><span><></span><span>0</span>
        <span>goto</span><span> error


    </span><span>if</span> <span>@exist_trancount</span> <span>=</span> <span>0</span>
        <span>--</span><span>提交事务</span>
        <span>commit</span> <span>tran</span><span> tran_proc
        </span><span>return</span> <span>1</span><span>
    error:
        </span><span>--</span><span>回滚事务或者事务保存点</span>
        <span>rollback</span> <span>transaction</span><span> tran_proc
        </span><span>return</span> <span>-</span><span>1</span>

<span>end</span></span>
登录后复制

解释:

1) 首先判断当前存储过程实例执行是否是嵌套事务调用。如果是嵌套,则存储过程判断的@@TRANCOUNT应该大于0,此时创建一个事务保存点,而非开启新事务;如果不是嵌套事务,则@@TRANCOUNT应该为0,此时开启新事务即可

2)然后,是存储过程本身的业务处理代码,每一步处理代码需要判断@@ERROR,如果0,执行error代码

3)最后,如果处理正确执行,并且非嵌套调用,则提交事务;如果发生错误,则回滚事务或者回滚保存点。

 

当然调用存储过程的地方,需要判断存储过程的返回值来做相应的处理

 

如有不对的地方,欢迎拍砖;如有其他方法,求分享,谢谢!O(∩_∩)O

 

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号