我有以下课程:
public class Order
{
public Order() { LineItems = new List<OrderLineItem>(); }
public int OrderID { get; set; }
..
public virtual ICollection<OrderLineItem> LineItems { get; set; }
..
}
public class OrderLineItem
{
public int OrderLineItemID { get; set; }
public int ProductID { get; set; }
public virtual Product Product { get; set; }
public int Quantity { get; set; }
}
public class Product
{
public int ProductID { get; set; }
...
}
当我坚持订单时,我已将OrderLineItems设置为适当的字段。但是,在使用以下代码将其保存到数据库之后:
public void SaveOrder(Order ord)
{
if (ord.OrderID == 0)
{
context.Orders.Add(ord);
}
else
{
var currentCat = context.Orders.Find(ord.OrderID);
if (currentCat != null)
context.Entry(currentCat).CurrentValues.SetValues(ord);
else
context.Entry(ord).State = EntityState.Modified;
}
context.SaveChanges();
}
OrderLineItem.Product对象为null。它具有相应的ProductID集,但不会填充实际产品。我尝试了一些类似于以下的不同映射,但我对实体框架有点新意。
modelBuilder.Entity<OrderLineItem>()
.HasRequired(c => c.Product);
任何帮助都将非常感激。
答案 0 :(得分:0)
我相信你必须遍历产品并添加()它们。