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

本文关键字:对象 集合 更新 LINQ 循环 使用 | 更新日期: 2023-09-27 18:22:11

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

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

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时,它仍然显示原始值。

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

尝试以下操作:

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实际上是一个查询语句,而不是记录本身。

基本上,您要做的是向方法发送一个查询,然后使用该方法来选择项目并更改它们。实际项目没有更改。

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

这也应该很有用:IQueryable、List、IEnumerator之间的差异?