此代码有时适用于某些项目,但在尝试处理更多项目时总是失败,我会得到这个:{"The underlying provider failed on Open."}
异常
List<Recon> scenarioAll = db.Transactions
.Where(t => t.SrcObjTyp == "13")
.Select(t => t.Recon).ToList();
//db.Transactions.Where(t => t.SrcObjTyp == "13").ToList().ForEach(t => reconsWithType13Trans.Add(t.Recon));
Parallel.ForEach(scenarioAll.Take(100), r =>
{
// ### Exception : {"The underlying provider failed on Open."} here ###
invoices = r.Transactions.SelectMany(t => t.InvoiceDetails).ToList();
CreateFacts(invoices, r/*, db*/).ForEach(f => facts.Add(f));
transactions = r.Transactions.Where(t => !t.SrcObjTyp.Contains("13")).ToList();
DistributeTransactionOnItemCode(transactions, facts);
Console.WriteLine(i += 1);
});
facts.ForEach(f => db.ReconFacts.Add(f));
db.SaveChanges();
我认为问题是多个进程同时访问数据库是否可以允许 EF 以这种方式被多个进程查询?
还有一种方法可以将所有内容加载到内存中,因此当访问Recon
类似的孩子时,r.Transactions.SelectMany(t => t.InvoiceDetails).ToList();
所有内容都将在内存中而不是访问底层数据库?
我应该使用您认为最好的解决方案吗?