linq查询似乎无法看到我的模型

时间:2014-10-15 22:19:35

标签: c# linq entity-framework asp.net-mvc-4

我的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; }
 }

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

    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?)

1 个答案:

答案 0 :(得分:1)

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