ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

在C#循环中调用SQL存储过程时处理事务

2019-11-18 08:17:55  阅读:290  来源: 互联网

标签:loops sql c sql-server stored-procedures


我正在开发一个已经由其他开发人员开发的系统.
并且在该系统中,他们调用了一个存储过程,该过程用于在C#中以循环方式在不使用用户定义表类型的情况下在循环中插入记录.

我需要做的就是在这种情况下添加一个事务.但是问题是我不知道交易地点.

我想知道是否在C#代码中使循环翘曲或在存储过程中进行了扭曲.

解决方法:

您只能在C#循环中使用它.在过程内部启动的事务必须在过程退出之前提交. SQL Server在运行过程之前和之后检查@@TRANCOUNT,如果结果不匹配,则会引发异常.因此,过程无法启动必须由调用方提交的事务.

最简单的想法是将C#代码包装在事务范围中:

using(var scope =  new TransactionScope(
      TransactionScopeOption.Required, 
      new TransactionOptions() {
         IsolationLevel = IsolationLevel.ReadCommitted
      })) {
   // Do the work here
   scope.Complete();
}

请注意,传递IsolationLevel = IsolationLevel.ReadCommitted为critical.

标签:loops,sql,c,sql-server,stored-procedures
来源: https://codeday.me/bug/20191118/2026786.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有