我找不到这个的具体例子,所以我发布的问题。任何帮助赞赏。比较两个大的通用名单
我有两个大的通用列表,都有超过300K项目。
我正在循环第一个列表以回收信息,并为动态生成新列表生成一个新项目,但是我需要在第二个列表中搜索并根据三个匹配条件返回一个值,如果找到要添加到列表中,但正如你可以想象的那样,做这个300k * 300k次需要时间。
有什么办法可以更有效地做到这一点?
我的代码:
var reportList = new List<StocksHeldInCustody>();
foreach (var correctDepotHolding in correctDepotHoldings)
{
var reportLine = new StocksHeldInCustody();
reportLine.ClientNo = correctDepotHolding.ClientNo;
reportLine.Value = correctDepotHolding.ValueOfStock;
reportLine.Depot = correctDepotHolding.Depot;
reportLine.SEDOL = correctDepotHolding.StockCode;
reportLine.Units = correctDepotHolding.QuantityHeld;
reportLine.Custodian = "Unknown";
reportLine.StockName = correctDepotHolding.StockR1.Trim() + " " + correctDepotHolding.StockR2.Trim();
//Get custodian info
foreach (var ccHolding in ccHoldList)
{
if (correctDepotHolding.ClientNo != ccHolding.ClientNo) continue;
if (correctDepotHolding.Depot != ccHolding.Depot) continue;
if (correctDepotHolding.StockCode != ccHolding.StockCode) continue;
if (correctDepotHolding.QuantityHeld != ccHolding.QuantityHeld) continue;
reportLine.Custodian = ccHolding.Custodian;
break;
}
reportList.Add(reportLine);
}
在对象创建的所有瓦尔的哈希在一起,只检查这些,它必须跑得快那么 – EaterOfCode 2012-08-15 09:28:36
数据的来源是什么?如果它是一个体面的数据库,这可能会做得更好。 – 2012-08-15 09:31:19
更新了我的通用答案,详细介绍了如何在linq中执行外连接 – Arkiliknam 2012-08-16 08:27:59