我开始使用带有 MVC 的 EF Code First 并且有点难过。我有以下数据库结构(对不起,不幸的是我不允许发布图片):
表 - 产品
表 - 相关产品
Products.ProductID 上的
1-Many -> RelatedProducts.ProductID 产品.ProductID 上的 1-Many -> RelatedProducts.RelatedProductID
基本上我有一个产品,可以有一系列与之相关的产品。这些保存在 RelatedProducts 表中,关系由 ProductID 和我命名为 RelatedProductID 的相关产品的 ProductID 定义。在我的代码中,我生成了以下类:
public class MyDBEntities : DbContext
{
public DbSet<Product> Products { get; set; }
public DbSet<RelatedProduct> RelatedProducts { get; set; }
}
public class Product
{
public Guid ProductID { get; set; }
public string Name { get; set; }
public string Heading { get; set; }
public string Description { get; set; }
public decimal Price { get; set; }
public Guid CategoryID { get; set; }
public string ImageURL { get; set; }
public string LargeImageURL { get; set; }
public string Serves { get; set; }
public virtual List<RelatedProduct> RelatedProducts { get; set; }
}
public class RelatedProduct
{
public Guid ProductID { get; set; }
public Guid RelatedProductID { get; set; }
public virtual Product Product { get; set; }
public virtual Product SimilarProduct { get; set; }
}
然后我尝试使用以下代码在代码中访问这些:
myDB.Products.Include("RelatedProducts").Where(x => x.ProductID == productID).FirstOrDefault();
但我不断收到以下错误:
{"Invalid column name 'ProductProductID2'.\r\nInvalid column name 'ProductProductID2'.\r\nInvalid column name 'ProductProductID'.\r\nInvalid column name 'ProductProductID1'.\r\nInvalid column name 'ProductProductID2'."}
我究竟做错了什么?我基本上想获得一个产品,然后遍历 RelatedProducts 并显示该产品信息。