加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-15 22:44:33 所属栏目:百科 来源:网络整理
导读:我的数据库中有一个表结构,如下所示: Items = User = Transactions 所以在C#映射类中,User包含Items和Transactions的集合……(1对多关系).. 所以我现在所做的就是: var filteredProducts = ctx.Transactions.Where(x = x.SearchedUserID == firstRequest.S
我的数据库中有一个表结构,如下所示:

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();

因此,您可以看到我正在按事务表中的数据进行分组…现在我想在这里做什么,如果可能的话,以一种简单的方式将User表转换为Items表并选择一个特定的属性需要从它为该分组项目,即CurrentPrice,并且表Transactions不包含此数据…

所以在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();

有人可以帮我吗 ?

解决方法

至于我得到你的表模式,你应该在SearchUserId过滤数据的同时从用户表开始查询,所以首先用User表关系获取数据

注意:由于我不知道您的表架构UserId在此示例代码中被视为User表主键和Transactions和Items表外键

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

然后尝试过滤,分组,…数据.但是,如果要选择问题中提到的内容,则应该在“项目”和“事务”表之间建立关系.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读