首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >System.Transactions.TransactionException

System.Transactions.TransactionException
EN

Stack Overflow用户
提问于 2015-05-05 20:46:42
回答 1查看 3K关注 0票数 1

我有以下代码:

代码语言:javascript
复制
[TestMethod]
        public void CalculateThatWeHaveAllRetrunFromProxyImmo()
        {
            var test = new BaseDataAccess();
            var sessionDateParam = new SqlParameter("@SessionDate", new DateTime(1900, 01, 31));
            var dateDebutParam = new SqlParameter("@DateDebutHistoricRendement", new DateTime(1999, 01, 31));
            var datefinParam = new SqlParameter("@DateFinHistoricRendement", new DateTime(2015, 01, 31));
            var idProxyParam = new SqlParameter("@IdRealEstateProxy", 15);
            var blocElementParam = new SqlParameter("@BlocNbrElement", 1501);

            for (int index = 0; index < 17; index++)
            {
                Debug.WriteLine("Passage : " + index);
                var ds = new DataSet();
                SqlConnection conn = null;
                using (conn = test.CreateAndOpenConnection())
                {
                    SqlCommand cmd = null;
                    using (cmd = new SqlCommand("[Core].[cp_CalculAllReturnProxyImmo]", conn))
                    {
                        cmd.CommandType = CommandType.StoredProcedure;
                        cmd.CommandTimeout = 1000000;

                        cmd.Parameters.Add(sessionDateParam);
                        cmd.Parameters.Add(dateDebutParam);
                        cmd.Parameters.Add(datefinParam);
                        cmd.Parameters.Add(idProxyParam);
                        cmd.Parameters.Add(blocElementParam);

                        using (SqlDataAdapter adapter = new SqlDataAdapter(cmd))
                        {
                            adapter.Fill(ds);
                        }

                        cmd.Parameters.Clear();
                    }
                }
            }

代码语言:javascript
复制
/// <summary>
        ///     Creates our connection to the database.
        /// </summary>
        /// <returns>The SqlConnection object.</returns>
        public SqlConnection CreateAndOpenConnection()
        {
            SqlConnection connection = null;

            try
            {
                connection = new SqlConnection(Settings.Default.DbConnection);
                connection.Open(); // the error appears here after 14 iterations

            }
            catch (SqlException sqlException)
            {

            }
            catch (Exception exception)
            {

            }

            return connection;
        }

这是连接

代码语言:javascript
复制
connectionString="Data Source=xxx\yyy;Initial Catalog=BD;Integrated Security=True;Max Pool Size=5000"

每当我到达循环中的指数14时,我就得到一个System.Transactions.TransactionException。但我的代码中没有打开任何事务。我不明白。

以下是完整的堆栈:

代码语言:javascript
复制
à 

System.Transactions.TransactionState.EnlistPromotableSinglePhase(InternalTransaction tx, IPromotableSinglePhaseNotification promotableSinglePhaseNotification, Transaction atomicTransaction)
   à System.Transactions.Transaction.EnlistPromotableSinglePhase(IPromotableSinglePhaseNotification promotableSinglePhaseNotification)
   à System.Data.SqlClient.SqlInternalConnection.EnlistNonNull(Transaction tx)
   à System.Data.SqlClient.SqlInternalConnection.Enlist(Transaction tx)
   à System.Data.SqlClient.SqlInternalConnectionTds.Activate(Transaction transaction)
   à System.Data.ProviderBase.DbConnectionInternal.ActivateConnection(Transaction transaction)
   à System.Data.ProviderBase.DbConnectionPool.PrepareConnection(DbConnection owningObject, DbConnectionInternal obj, Transaction transaction)
   à System.Data.ProviderBase.DbConnectionPool.TryGetConnection(DbConnection owningObject, UInt32 waitForMultipleObjectsTimeout, Boolean allowCreate, Boolean onlyOneCheckConnection, DbConnectionOptions userOptions, ref DbConnectionInternal connection)
   à System.Data.ProviderBase.DbConnectionPool.TryGetConnection(DbConnection owningObject, TaskCompletionSource`1 retry, DbConnectionOptions userOptions, ref DbConnectionInternal connection)
   à System.Data.ProviderBase.DbConnectionFactory.TryGetConnection(DbConnection owningConnection, TaskCompletionSource`1 retry, DbConnectionOptions userOptions, DbConnectionInternal oldConnection, ref DbConnectionInternal connection)
   à System.Data.ProviderBase.DbConnectionInternal.TryOpenConnectionInternal(DbConnection outerConnection, DbConnectionFactory connectionFactory, TaskCompletionSource`1 retry, DbConnectionOptions userOptions)
   à System.Data.ProviderBase.DbConnectionClosed.TryOpenConnection(DbConnection outerConnection, DbConnectionFactory connectionFactory, TaskCompletionSource`1 retry, DbConnectionOptions userOptions)
   à System.Data.SqlClient.SqlConnection.TryOpenInner(TaskCompletionSource`1 retry)
   à System.Data.SqlClient.SqlConnection.TryOpen(TaskCompletionSource`1 retry)
   à System.Data.SqlClient.SqlConnection.Open()
   à System.Data.Common.DbDataAdapter.FillInternal(DataSet dataset, DataTable[] datatables, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
   à System.Data.Common.DbDataAdapter.Fill(DataSet dataSet, Int32 startRecord, Int32 maxRecords, String srcTable, IDbCommand command, CommandBehavior behavior)
   à System.Data.Common.DbDataAdapter.Fill(DataSet dataSet)
   à MarketRisk.dVar.IntegrationTests.Service.Managers.RealEstateProxyCreationManagerFixture.CalculateThatWeHaveAllRetrunFromProxyImmo() dans RealEstateProxyCreationManagerFixture.cs: line 67

调试跟踪:

调试跟踪:

代码语言:javascript
复制
Passage : 0
Passage : 1
Passage : 2
Passage : 3
Passage : 4
Passage : 5
Passage : 6
Passage : 7
Passage : 8
Passage : 9
Passage : 10
Passage : 11
Passage : 12
Test method 
MarketRisk.dVar.IntegrationTests.Service.Managers.RealEstateProxyCreationManagerFixture.CalculateThatWeHaveAllRetrunFromProxyImmo Threw exception :
System.Transactions.TransactionException : The operation is not valid for the state of the transaction. ---> System.TimeoutException : Delay transaction time
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-05-07 11:56:19

根据请求,您将Assert.IsTrue(Transaction.Current == null);添加到测试中。断言被触发了。这证明了存在一个您不知道的System.Transactions.Transaction集。这就解释了症状。您无意中使用了分布式事务(如果不使用MSDTC服务,最好禁用它们,这样它们就会立即失败,而不是有时!)。

不可能知道交易在哪里安装的。Grep“事务”的整个源代码。添加更多的断言。

也许,一个不同的测试已经设置了该事务并泄露了它。交叉测试交互很难调试。缩小范围,逐步减少运行的测试集,直到问题消失。

我应该杀了那笔交易吗?

这是不合适的。找出根本原因,而不是治疗症状。不应该有你不知道的tran。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30062967

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档