linq查询似乎看不到我的模型

本文关键字:我的 模型 看不到 查询 linq | 更新日期: 2023-09-27 18:26:44

InventoryGridModel中有5个属性,我在每个属性上都得到一个错误,说模型不包含该属性。显然,模型确实如此,所以不确定发生了什么,就像代码无法读取模型一样。

型号:

 public class InstrumentGridModel
 {
     public int InstrumentId { get; set; }
     public string ItemName { get; set; }
     public string SerialNumber { get; set; }
     public string CaseNumber { get; set; }
     public string LocationName { get; set; }
     public string SiteCode { get; set; }
 }

应该从数据库中提取信息并填充模型的方法:

    public List<InstrumentGridModel> GetInstruments()
    {
        var results = new List<InstrumentGridModel>();
        var data = from i in db.Instrument
                   join l in db.Location on i.LocationId equals l.LocationId
                   join t in db.InventoryItem on i.ItemId equals t.ItemId
                   select new InstrumentGridModel
                   {
                       InstrumentId = i.InstrumentId,
                       ItemName = t.ItemName,
                       SerialNumber = i.SerialNumber,
                       CaseNumber = i.CaseNumber,
                       LocationName = l.LocationName
                   };
        foreach (var i in data)
        {
            results.Add(new InstrumentGridModel()
            {
                InstrumentId = data.InstrumentId,
                ItemName = data.ItemName,
                SerialNumber = data.SerialNumber,
                CaseNumber = data.CaseNumber,
                LocationName = data.LocationName
            });
        }
        return results;
    }

错误(注意这只是一个错误,我在所有5个属性上都得到了相同的错误):

Error   3   'System.Linq.IQueryable<MusicInventory.Models.InstrumentGridModel>' does not contain a definition for 'ItemName' and no extension method 'ItemName' accepting a first argument of type 'System.Linq.IQueryable<MusicInventory.Models.InstrumentGridModel>' could be found (are you missing a using directive or an assembly reference?)

linq查询似乎看不到我的模型

您正在foreach循环中对data进行迭代。但是,您可以访问data(我想它的类型是System.Linq.IQueryable<MusicInventory.Models.InstrumentGridModel>)。但是,您要做的是使用ìin the loop instead of数据`,即访问单个项目,而不是集合。

相关文章: