我的数据库中有一个表结构,如下所示:
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 })
然后尝试过滤,分组,…数据.但是,如果要选择问题中提到的内容,则应该在“项目”和“事务”表之间建立关系.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。