【发布时间】:2015-02-28 02:25:40
【问题描述】:
我花了一天时间尝试将 sql 查询转换为 LINQ lambda 表达式,但没有成功。
我的sql查询:
SELECT a.ID,
Sum(b.[Value]) AS [Value],
c.ContractValue
FROM Contracts a
LEFT JOIN DepositHistories b
ON b.ContractID = a.ID
INNER JOIN LearningPackages c
ON a.LearningPackageID = c.ID
GROUP BY a.ID,
c.ContractValue
HAVING Sum(b.[Value]) < c.ContractValue
OR Sum(b.[Value]) IS NULL
OR Sum(b.[Value]) = 0
这是 LINQ 查询:
var contracts = (
from a in db.Contracts
from b in db.LearningPackages.Where(e => e.ID == a.LearningPackageID).DefaultIfEmpty()
group a by new
{
a.ID,
b.ContractValue
} into g
from c in db.DepositHistories.Where(e => e.ContractID == g.Key.ID).DefaultIfEmpty()
where g.Sum(e => c.Value) < g.Key.ContractValue || g.Sum(e => c.Value) == null
select new
{
ID = g.Key.ID,
ContractValue = g.Key.ContractValue,
Value = g.Sum(e => c.Value != null ? c.Value : 0)
}
).ToList();
我的结果:
ID ContractValue Value
1 6000000 500000
1 6000000 500000
1 6000000 500000
1 6000000 500000
1 6000000 500000
3 7000000 500000
3 7000000 500000
3 7000000 500000
4 6000000 500000
5 6000000 0
6 6000000 0
这不是对值进行分组和求和。
请帮帮我!
谢谢!
【问题讨论】:
-
你一整天都在尝试什么?展示你的努力。
-
我们不是代码编写服务。我们帮助修复无效或不完整的代码。
-
您确定不希望在您的 LEFT JOIN 之前执行此 INNER JOIN 吗????
-
@M.Ali:连接不一定按照它们声明的顺序执行。
-
我只是更新我的代码,请帮助我!
标签: c# sql-server linq lambda