TimeoutException 问题。
上下文:Visual Studio 2010
问题:我偶尔(在每小时运行一次的程序上每天一次)遇到我不理解的异常。
这是一个例外:
Exception message : The transaction has aborted.
Exception Source : System.Transactions
Exception Trace : at System.Transactions.TransactionStateAborted.BeginCommit(InternalTransaction tx, Boolean asyncCommit, AsyncCallback asyncCallback, Object asyncState)
at System.Transactions.CommittableTransaction.Commit()
at System.Transactions.TransactionScope.InternalDispose()
at System.Transactions.TransactionScope.Dispose()
at JDTranslation_K4_ReadEmails.Form1.ReadEmailDetails(EmailMessage emMessage, String strUserName, String strAccountName)
Exception Target : Void BeginCommit(System.Transactions.InternalTransaction, Boolean, System.AsyncCallback, System.Object)
异常通常发生在持续 25-30 分钟的事务之后。
我已将交易设置为持续 5 小时(见下文),所以我完全不明白为什么它会超时。
而且我有点担心:我知道一些数据已提交到数据库 - 我可以相信它们都是吗?(几乎不可能通过调查数据来验证。)
程序(函数的一部分)大致如下所示:
//INSTANTIATE THE TRANSACTION SCOPE
TransactionOptions option = new TransactionOptions();
//SET THE ISOLATION LEVEL AND THE TIMEOUT DURATION
option.IsolationLevel = System.Transactions.IsolationLevel.ReadCommitted;
option.Timeout = new TimeSpan(5, 0, 0);
using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required, option))
{
try{
// do some select/update/insert/delete stuff on both connections,
// up to perhaps 3600 actions
// some of it happens in static functions declared elsewhere in the same class scope
} // this is the line mentioned in the Exception
}
我很乐意回答我的一些问题:
为什么会发生异常?
我可以相信所有数据都已提交,还是 C#.NET 中存在允许部分提交的真正错误?
我的代码是否正确,或者我应该以不同的方式组织它来解决问题?
请帮忙!