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