下面的代码会引发以下异常。我究竟做错了什么?
错误堆栈:System.Transactions.TransactionAbortedException:事务已中止。---> System.Data.SqlClient.SqlException:事务操作无法执行,因为有待处理的请求正在处理此事务。
public class NestedTransaction
{
public void SomeTransaction()
{
using (var context = new SomeDBContext())
{
using (TransactionScope transaction = new TransactionScope(TransactionScopeOption.Required,
new TransactionOptions { IsolationLevel = IsolationLevel.ReadCommitted }))
{
context.Connection.Open();
List<SomeEntities> entities = GetEntitiesFromDatabase();
entities.ForEach(entity =>
{
SaveEntity((EntityConnection)context.Connection, entity);
});
context.SaveChanges();
context.Connection.Close();
transaction.Complete();
}
}
}
private static void SaveEntity(EntityConnection connection,SomeEntity entity)
{
foreach (SomeEntity childEntity in entity.ChildEntities)
{
SaveEntity(connection, childEntity)
}
}
}
在此先感谢 Niju