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