停止调试器时,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服务已停止,我刚刚启动并按预期工作。

我认为,在那种情况下,它应该抛出一个异常,但是知识就是力量,下一次我将尝试不花太多时间。

谢谢。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...