У меня есть следующий сценарий:
using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required, new TransactionOptions { IsolationLevel = IsolationLevel.ReadCommitted },EnterpriseServicesInteropOption.Automatic))
{
using (DataContext db = new DataContext())
{
db.Connection.Open();
db.Transaction = db.Connection.BeginTransaction();
try
{
bool outcome = InvokeInTransaction<string, object>(inputDict, out outputDict);
db.Transaction.Commit();
}
catch (Exception ex)
{
response.Outcome = BusinessEntityResponse.SystemError;
db.Transaction.Rollback();
}
}
}
Внутри вызова InvokeInTransaction есть ряд вызовов, сделанных в хранилище LTS для выполнения различных изменений данных.Проблема в том, что внутри хранилища есть еще один
using (var db = new DataContext())
, внутри которого находится постоянный код.Проверка контекста в репозитории показывает Transaction = null, и я подозреваю, что «внутренний» контекст не знает о транзакции Ambient.Можно ли это сделать?Я понимаю, что EF управляет этим под прикрытием, и ограничение заключается в том, что код хранилища не может быть изменен.Любая помощь?