使用LINQ循环和更新集合中的对象值

时间:2014-09-17 19:19:40

标签: c# .net linq

我想遍历集合中的每个对象,然后使用另一个数组集合更新每个对象的属性

我的用例是我有一些实体,我最初从我的集合中读取到一个数组中,并执行一些复杂的计算,然后更新我的原始集合。

public void WhatIfCalculation(string Product, string SiteID, System.Linq.IQueryable<DAL.OMS_StockStatus> prodStatus, ref System.Linq.IQueryable<PivotViewModel> activityInfo)
{
    var sff = activityInfo.Where(a => a.Activity == "System Forecast" && a.SiteID == SiteID).ToList();

    aSFF = new double?[sff.Count()];
    for (int i = 0; i < sff.Count(); i++)
    {
        aSFF[i] = sff.ElementAt(i).Value + 1;
    }

    var prf = activityInfo.Where(a => a.Activity == "Planned Receipts" && a.SiteID == SiteID).ToList();
    aPRF = new double?[prf.Count()];
    for (int i = 0; i < prf.Count(); i++)
    {
        aPRF[i] = prf.ElementAt(i).Value + 2;
    }

    // Will perform some calculation here. And then update back my collection.

    for (int i = 0; i < aSFF.Length; i++)
    {
        activityInfo.Where(a => a.Activity == "System Forecast" && a.SiteID == SiteID).ToList().ElementAt(i).Value = aSFF[i];
    }

    for (int i = 0; i < aPRF.Length; i++)
    {
        activityInfo.Where(a => a.Activity == "Planned Receipts" && a.SiteID == SiteID).ToList().ElementAt(i).Value = aPRF[i];
    }
}

但以上更新并未更新我的收藏。当我浏览我的activityInfo时 - 它仍显示原始值。

1 个答案:

答案 0 :(得分:1)

尝试以下方法:

public void WhatIfCalculation(string Product, string SiteID, List<DAL.OMS_StockStatus> prodStatus, List<PivotViewModel> activityInfo)
{
    var sff = activityInfo.Where(a => a.Activity == "System Forecast"); // Do this in the calling function >> .Where(a => a.SiteID == SiteID).ToList();

    aSFF = new double?[sff.Count()];
    for (var i = 0; i < sff.Count(); i++)
    {
        aSFF[i] = sff.ElementAt(i).Value + 1;
    }

    var prf = activityInfo.Where(a => a.Activity == "Planned Receipts");
    aPRF = new double?[prf.Count()];
    for (var i = 0; i < prf.Count(); i++)
    {
        aPRF[i] = prf.ElementAt(i).Value + 2;
    }

    // Will perform some calculation here. And then update back my collection.

    for (var i = 0; i < aSFF.Length; i++)
    {
        sff.ElementAt(i).Value = aSFF[i];
    }

    for (var i = 0; i < aPRF.Length; i++)
    {
        prf.ElementAt(i).Value = aPRF[i];
    }
}

正如您所看到的,我正在向该方法发送一个列表而不是IQueryable。原因是IQueryable实际上是一个查询语句而不是记录本身。

基本上你正在做的是向方法发送一个查询,用于选择项目并更改它们。实际项目不会更改。

使用以下示例,您将发送实际项目的列表。这些项目可以更改。我还从您的方法中删除了一些双选语句以提高速度。

这也应该有用:Differences between IQueryable, List, IEnumerator?