我知道有类似问题的基调,我经历过很多,但仍然无法掌握如何在LINQ中做到这一点。我需要创建一个查询来获取数据,就像这个纯SQL查询一样:
SELECT p.ProcessId, p.Description, p.StartedOn, p.StartedBy, uuus.Name + ' ' + uuus.Surname AS StartedByName, p.FinishedOn, p.FinishedBy, uuu.Name + ' ' + uuu.Surname as FinishedByName, p.PlannedFinish, p.PlannedStart, COUNT(CASE WHEN h.IsCompleted IS NULL AND h.HandlingId IS NOT NULL THEN 1 END)
FROM JDE_Processes p LEFT JOIN JDE_Users uuu ON p.FinishedBy = uuu.UserId LEFT JOIN JDE_Handlings h ON h.ProcessId=p.ProcessId LEFT JOIN JDE_Users uuus ON uuus.UserId=p.StartedBy
GROUP BY p.ProcessId, p.Description, p.StartedOn, p.StartedBy,uuus.Name + ' ' + uuus.Surname, p.FinishedOn, p.FinishedBy, uuu.Name + ' ' + uuu.Surname, p.PlannedFinish, p.PlannedStart, p.Createdon
ORDER BY p.CreatedOn DESC
这是我的linq版本,它主要工作,但我无法弄清楚“如果h.IsCompleted=0计数”部分。
var items = (from p in db.JDE_Processes
join uuu in db.JDE_Users on p.FinishedBy equals uuu.UserId into finished
from fin in finished.DefaultIfEmpty()
join h in db.JDE_Handlings on p.ProcessId equals h.ProcessId into hans
from ha in hans.DefaultIfEmpty()
group new { p, fin }
by new {
p.ProcessId,
p.Description,
p.StartedOn,
p.StartedBy,
p.FinishedOn,
p.FinishedBy,
p.PlannedFinish,
p.PlannedStart,
fin.Name,
fin.Surname
} into grp
orderby grp.Key.ProcessId descending
select new Process
{
ProcessId = grp.Key.ProcessId,
Description = grp.Key.Description,
StartedOn = grp.Key.StartedOn,
StartedBy = grp.Key.StartedBy,
FinishedOn = grp.Key.FinishedOn,
FinishedBy = grp.Key.FinishedBy,
});
问题:
1)如何让“如果h.IsCompleted=0计数”工作?
2) 我可以使用某种别名吗?我的意思是,在这个查询的实际版本中,还有另一个左连接,它导致我在grp中有2个名字和2个姓氏列。然后,如何将适当的字段分配给正确的输出字段?我的意思是像下面这样:join uuu in db.JDE_Users on p.StartedBy equals uuu.UserId into started
from star in started.DefaultIfEmpty()
一只斗牛犬
慕桂英3389331
相关分类