簡體   English   中英

LINQ 到實體:如何通過謂詞獲取所有值

[英]LINQ to Entitites: How to take all values by a predicate

我正在嘗試獲取具有相同謂詞的所有值。 例如:我有許多包記錄,其中包含它自己的 Id、Data 和 DeviceId,這表明 package 來自哪個設備。

這是我創建的 function,它只返回第一個 package

 public Package GetPackageByDeviceId(int id)
    {
        return avldbContext.Packages.Where(p => p.DeviceId == id).FirstOrDefault();
    }

關於如何獲得所有包裹的任何建議?

public IEnumerable<Package> GetPackagesByDeviceId(int id)
{
    return avldbContext.Packages.Where(p => p.DeviceId == id);
}
public List<Package> PackagesByDeviceId(int id)
{
    return avldbContext.Packages.Where(p => p.DeviceId == id).ToList();
}

首先,您需要指定方法的“s”字符結尾。 因為該方法返回多行。 比沒有 FirstOrDefault()。 您需要放置一個 ToList() 擴展方法來提取所有記錄。 祝你好運。

編輯:順便說一句,您的代碼看起來仍在尋找主鍵。 您需要擴展您的預測。

如果你想得到IEnumerable結果

public IEnumerable<Package> GetPackagesByDeviceId(int id)
{
    return avldbContext.Packages.Where(p => p.DeviceId == id);
}

或者,如果您想獲取List

public List<Package> GetPackagesByDeviceId(int id)
{
    return avldbContext.Packages.Where(p => p.DeviceId == id).ToList();
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM