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

我正在开发一个已经由其他开发人员开发的系统.
并且在该系统中,他们调用了一个存储过程,该过程用于在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.

上一篇:数字矩阵JavaScript


下一篇:javascript-将随机类应用于多个元素组,而无需重复