如何解决停止调试器时,C#TransactionScope不会回滚
我有这个简单的代码,可以在Controller,ASP Net 4.6和SQL Server 2014的运行时中很好地工作,但是当以调试模式运行时(逐步),并且在事务范围中间停止处理时,数据库已提交。怎么可能?
void RootMethod()
{
using (TransactionScope scope = new TransactionScope())
{
DoSql("Update myTable Set " +
"MyField = 'value' " +
"Where " +
"Id = 'test');
//stop here
Console.WriteLine("OK");
DoSql("Update myTable Set " +
"MyField = 'secondValue' " +
"Where " +
"Id = 'test');
scope.Complete();
}
}
对代码进行了简化,以最大程度地减少复杂性以及SQL语句。 “ DoSql”功能是带有以下代码的帮助程序:
public static void DoSql(string cCmdSql)
{
string connStr = "uid=userdb;pwd=xxxxxx;server=MyServer;database=MyDatabase;Application Name=\"WebApp\";
using (SqlConnection conn = new SqlConnection(connStr))
{
try
{
conn.Open();
SqlCommand selectCmd = new SqlCommand(cCmdSql,conn);
SqlDataAdapter oAda = new SqlDataAdapter();
oAda.SelectCommand = selectCmd;
oAda.SelectCommand.CommandTimeout = 300;
DataSet oDs = new DataSet();
oAda.Fill(oDs);
}
catch (SqlException ex)
{
Console.WriteLine("SQL: " + cCmdSql + ex.Message);
throw;
}
}
return;
}
当我在事务中间调试进程时,必须停止该进程以更正它,我需要事务进行回滚,而实际上并不需要。
但是在运行时,如果我放置Transaction.Current.Rollback()或sql语句失败,则事务将回滚。
解决方法
谢谢大家。
是的,MSDTC服务已停止,我刚刚启动并按预期工作。
我认为,在那种情况下,它应该抛出一个异常,但是知识就是力量,下一次我将尝试不花太多时间。
谢谢。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。