System.Transactions.TransactionException
System.Transactions.TransactionException
我有以下代码:
[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();
}
}
}
和
/// <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;
}
这是连接
connectionString="Data Source=xxx\yyy;Initial Catalog=BD;Integrated Security=True;Max Pool Size=5000"
每次我在循环中到达索引 14 时,我都会得到一个 System.Transactions.TransactionException
。
但是我的代码中没有打开任何事务。没看懂。
这是完整的堆栈:
à
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
调试跟踪:
调试跟踪:
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
根据要求,您将 Assert.IsTrue(Transaction.Current == null);
添加到测试中。断言被解雇了。这证明有一个 System.Transactions.Transaction
集是你不知道的。这就解释了症状。您无意中使用了分布式事务(如果您不使用它们,最好禁用 MSDTC 服务,这样它们会立即失败,而不是偶尔失败!)。
无法确定该交易的位置。 Grep "Transaction" 的整个源代码。添加更多断言。
可能是另一个测试设置了该事务并泄露了它。交叉测试交互很难调试。通过逐渐减少您 运行 直到问题消失的测试集来缩小范围。
Should i kill that Transaction
这是不合适的。找到根本原因而不是治疗症状。应该没有你不知道的tran
我有以下代码:
[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();
}
}
}
和
/// <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;
}
这是连接
connectionString="Data Source=xxx\yyy;Initial Catalog=BD;Integrated Security=True;Max Pool Size=5000"
每次我在循环中到达索引 14 时,我都会得到一个 System.Transactions.TransactionException
。
但是我的代码中没有打开任何事务。没看懂。
这是完整的堆栈:
à
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
调试跟踪:
调试跟踪:
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
根据要求,您将 Assert.IsTrue(Transaction.Current == null);
添加到测试中。断言被解雇了。这证明有一个 System.Transactions.Transaction
集是你不知道的。这就解释了症状。您无意中使用了分布式事务(如果您不使用它们,最好禁用 MSDTC 服务,这样它们会立即失败,而不是偶尔失败!)。
无法确定该交易的位置。 Grep "Transaction" 的整个源代码。添加更多断言。
可能是另一个测试设置了该事务并泄露了它。交叉测试交互很难调试。通过逐渐减少您 运行 直到问题消失的测试集来缩小范围。
Should i kill that Transaction
这是不合适的。找到根本原因而不是治疗症状。应该没有你不知道的tran