将本地列表操作与linq混合到实体数据库操作

时间:2011-05-18 16:30:39

标签: asp.net-mvc linq entity-framework linq-to-entities

我有2个清单。购物车列表,其中包含具有属性的对象; QuantityProductId。然后,我从购物车列表中包含IQueryable的存储库(ProductId)中获取所有产品。这意味着对于每个产品,都有一个与Quantity相关的购物车对象。

在进行选择时,我也想分配此Quantity,但我知道这样做的唯一方法是再次查询购物车。

对于egx。

        model = (from p in productService.GetAllProducts()
                              where cart.Entries.Select(c => c.ProductId).Contains(p.ProductId)
                              select new CartViewItem
                                         {
                                             Price = p.Price,
                                             ProductId = p.ProductId,
                                             ProductName = p.ProductName,
                                             Quantity = cart.Entries.FirstOrDefault(c => c.ProductId == p.ProductId).Quantity
                                         }).ToList();

型号:

public class ShoppingCartEntry
{
    public int ProductId { get; set; }
    public int Quantity { get; set; }
}

cart.Entries不是来自存储库。 productService.GetAllProducts()返回entityframework的IQueryable。

编辑:我的新代码是:

        model= (from p in productService.GetAllProducts()
                              from c in cart.Entries
                              where c.ProductId == p.ProductId
                              select new CartViewItem
                                         {
                                             Price = p.Price,
                                             ProductId = p.ProductId,
                                             ProductName = p.ProductName,
                                             Quantity = c.Quantity
                                         }).ToList();

这会抛出一个错误: Unable to create a constant value of type 'SampleApp.WebUI.Models.ShoppingCartEntry'. Only primitive types ('such as Int32, String, and Guid') are supported in this context.

1 个答案:

答案 0 :(得分:3)

我认为这应该有用......

var model = (from c in cart.Entires  // The small local cart collection
             let cpid = cart.Entires.Select(c2 => c2.ProjectId) // 
             from p in productService.GetAllProducts() // Query all Products used in cart
                               .Where(queryp => cpid.Contains(queryp.ProjectId)).ToList()
             where p.ProductId == c.ProductId
             select new CartViewItem {
                 p.Price,
                 p.ProductId,
                 p.Brand,
                 p.ProductName,
                 Discount = p.DiscountPercent * c.Quantity}).ToList();