c# - 执行 LINQ 连接,然后分组,然后对两个不同的列求和

标签 c# linq join group-by sum

我在项目中使用 LINQ to SQL,但在执行 joingroup by 来比较两个字段时遇到问题在每个表中。

这是我的查询:

var q =
   (from ii in
        (from a in table1
         join b in table2 on a.BudgetUnitID equals b.BudgetUnitID
         select new { BT = a.Amount, BA = b.Amount, BUID = a.BudgetUnitID, BU = a.BudgetUnit.BudgetUnitName })
    group ii by new {ii.BUID} into g
    select new
    {
        BudgetUnit = g.Key,
        Budget = g.Sum(x => x.BA),
        Actual = g.Sum(x => x.BT),
        Variance = g.Sum(x => x.BA) - g.Sum(x => x.BT)
    }).ToList();

我要将其绑定(bind)到网页上的 GridView 。我的问题是我没有在其中一列上获得正确的总数。

非常感谢您的帮助。

最佳答案

您的问题可能是预算金额不正确,因为您正在对每个组合进行求和。例如,如果您的预算数据如下所示:

Budget | Amount
Dev    | 2500

以及像这样的订单项:

Budget | Amount
Dev    | 1000
Dev    | 750

然后您在内部查询中将它们组合在一起,如下所示:

BA   | BT
2500 | 1000
2500 | 750

然后将它们加在一起,得到

Budget | Actual
5000   | 1750

在这种情况下,预算是应有的两倍,因为您要将每个组合的所有条目加在一起。您需要先对各个表求和,然后再将结果连接在一起,这样子查询数据中就不会出现这种“重复”问题:

var q =
   (from ii in
        (from a in table1 group a by a.BudgetUnitID into g
         select new { BudgetUnitID = g.Key, Amount = g.Sum(x => x.Amount) })
    join jj in
        (from b in table2 group b by b.BudgetUnitID into g
         select new { BudgetUnitID = g.Key, Amount = g.Sum(x => x.Amount) })
        on ii.BudgetUnitID equals jj.BudgetUnitID
         select new { Actual = ii.Amount, Budget = jj.Amount, Variance = jj.Amount - ii.Amount, BUID = ii.BudgetUnitID }
    ).ToList();

关于c# - 执行 LINQ 连接,然后分组,然后对两个不同的列求和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12007671/

相关文章:

mysql - 连接和计算问题

c# - 如何使用 EF Core 添加新表

c# - 我什么时候应该考虑代表主键......?

c# - 外连接父表和子表(嵌套)的 LINQ 查询

mysql - 加入两个表并从一个表中获取一组值

基于值的 Mysql 名称

c# - Monotouch 如何在 C# 中从 NSArray 检索 objectAtIndex

c# - 与 LINQ-to-XML 中的 InnerText 等效的是什么?

c# - 为什么 Select、Where 和 GroupBy 的这种组合会导致异常?

c# - 无法从 xtragridview 获取点击行的数据