3

我有包含 2 个表的数据库

TABLE Categories (CategoriesId, Name, Description)
TABLE Products (ProductId, CategoriesId, Title, ProductImageUrl)

类别通过 CategoriesId 链接到产品。

我正在尝试使用 LINQ 来获取所有特定的标题。

 public ActionResult Browse(string categories)
 {
     var spices = spiceDB.Products.Include("Products").Single(p => p.Title == categories);                 
     return View(spices);
 }

产品型号

namespace SpiceShop.Models
{
    public class Product
    {
        [Key]
        public int ProductId { get; set; }

        public int CategoriesId { get; set; }
        public string Title { get; set; }

        public string ProductImageUrl { get; set; }
        public List <Categorie> Name { get; set; }
    }
}

类别型号

namespace SpiceShop.Models
{
    public class Categorie
    {
        [Key]
        public int CategoriesId { get; set; }
        public string Name  { get; set; }

        public string Description { get; set; }
        //public List<Product> ProductId { get; set; }
        public List<Product> Products { get; set; }
    }
}
4

2 回答 2

6

只需删除 .Include("Products"),这不是它的使用方式。

错误很明显,您的“产品”模型中没有“产品”属性。

于 2013-02-28T01:00:35.260 回答
4

编辑:

看起来您的视图需要一个模型,它是“产品”类型的单个对象。

此外,我尝试为每个标识符/变量指定一个最能传达其含义和意图的名称。


编辑2:

请注意,更改方法上的任何输入参数名称都需要相应更改调用该方法的视图代码。
在 MVC 中,Action-Method 参数是自动映射的。
您的调试显示了一个 URL Browse?categories=Sauces,它自动映射到方法“Browse”,输入参数categories设置为“Sauces”。但是(我的版本) Browse 方法需要一个categoryName参数,而不是categories. 因此,您需要确保 URL 属性和方法参数具有完全相同的名称。


因此,如果您确实需要将所选类别的名称作为输入参数传递:

public ActionResult Browse(string categoryName)
{
    // Gets the CategoryId for the given categoryName, or zero if not found.
    var categoryId = spiceDB.Categories
        .Where(c => c.Name == categoryName)
        .Select(c => c.CategoriesId)
        .FirstOrDefault();

    // Gets the first Product (only) for the specified categoryId.
    var firstProduct = category.Products
        .FirstOrDefault(p => p.CategoriesId == categoryId);

    return View(firstProduct);
}

但是,支持这种类型的“父子”关系的更常见的使用场景是:

  • 您的类别列表在单击时按 ID 调用查询,而不是按名称查询(即 3,而不是“Pickles”)
  • 您的视图支持所有相关产品,而不仅仅是第一个(即类型的模型List<Product>,而不仅仅是Product

例如

public ActionResult Browse(int categoryId)
{
    var products = spiceDB.Products
        .Where(p => p.CategoriesId == categoryId) 
        .ToList();

    return View(products);
}

即使您的产品列表更全面,您的数据访问代码更简单、更高效。

于 2013-02-28T01:18:26.077 回答