LINQ Group通过跨多个表/类执行连接

时间:2017-05-13 10:20:02

标签: c# asp.net asp.net-mvc linq c#-4.0

我的数据库中有一个表结构,如下所示:

Items <=  User  => Transactions

所以在C#映射类中,User包含Items和Transactions的集合......(1对多关系)..

所以我现在所做的就是:

   var filteredProducts = ctx.Transactions.Where(x => x.SearchedUserID == 
    firstRequest.SearchedUserID)
    .OrderByDescending(x => x.TransactionDate)
    .GroupBy(x => x.TransactionID ).Select(x => new ResultItem()
    {
     TransactionID = x.Key,
     SaleNumber = x.Sum(y => y.QuantityPurchased)                 
     })
     .ToList();

因此,您可以看到我按交易表中的数据进行分组...现在我想在这里做什么,如果可能的话,以简单的方式跨越用户表进入项目表并从中为该分组项目选择我需要的特定属性,即CurrentPrice,并且表格事务不包含此数据......

所以在select语句中我想像这样提取CurrentPrice属性:

.Select(x => new ResultItem()
        {
         TransactionID = x.Key,
         SaleNumber = x.Sum(y => y.QuantityPurchased),
         CurrentPrice = // somehow go to Items table and pick up this data 
         })
         .ToList();

有人能帮助我吗?

1 个答案:

答案 0 :(得分:1)

就我获取表架构而言,您应该在SearchUserId过滤数据时从用户表开始查询,因此,首先使用用户表关系获取数据

注意:因为我不知道您的表架构UserId被视为User表主键,而TransactionsItems表是外来的键入此示例代码

    var result = (from usr in ctx.User
                 where  usr.UserId == firstRequest.SearchedUserID
                 select new {
                    UserId = usr.UserId,
                    Transactions = usr.Transactions,
                    Items = usr.Items
                 })

然后尝试过滤,分组,...数据。但是,如果您想要选择问题中提到的内容,则应该在ItemsTransactions表之间建立关联。