有没有人可以帮助解决C#代码的问题,以便以简化形式将此SQL实现为实体框架Linq?(例如,你在哪里有".“符号,如xxx.where(...等)
SELECT PN.Name, Sum(U.Amount)
FROM Usages as U, ProcessNames as PN
WHERE PN.Id == U.ProcessNameId
AND U.Datetime BETWEEN '2010-01-08' AND '2010-10-11'
Group By PN.Name发布于 2010-10-08 12:36:53
基于方法的查询:
要在lambda中实现这一点,我们需要利用
var query = context.ProcessNames
.GroupJoin(context.Usages
.Where(u => u.Datetime >= new DateTime(2010, 1, 8) )
&& u.Datetime <= new DateTime(2010, 10, 11),
pn => pn.Id,
u => u.ProcessNameId,
(pn, usages) => new { Name = pn.Name,
Sum = usages.Sum(u => u.Amount) });查询表达式:
并且在查询表达式语法中使用完全相同的查询:
var query =
from pn in context.ProcessNames
join u in context.Usages
.Where(u => u.Datetime >= new DateTime(2010, 1, 8) )
&& u.Datetime <= new DateTime(2010, 10, 11),
on pn.Id
equals u.ProcessNameId
into g
select new { Name = pn.Name,
Sum = g.Sum(u => u.Amount) };检查生成的SQL:
要验证这些查询是否在运行时为您提供了所需的Sql命令,您可以执行以下操作:
string sqlCommand = ((ObjectQuery)query).ToTraceString();更多示例:
有关GroupJoin上的一些很好的示例,请查看以下内容:
发布于 2010-10-08 11:33:04
试试这个(我没有你的代码,所以我没有得到编译器的帮助):
from u in context.Usages
join pn in context.ProcessNames on pn.Id equals u.ProcessNameId
where u.Datetime >= new DateTime(2010, 1, 8) && u.Datetime <= new DateTime(2010, 10, 11)
group pn by pn.Name into g
select new { Name = pn.Name , sum = g.Sum(u => u.Amount) };这是它的查询表达式版本。要获得基于lambda的语法(我相信您是在问这个问题),将查询放入LinqPad并运行它。然后单击LinqPad中的lambda选项卡,它将向您显示上面查询的语法,就像您用lambda表达式编写的一样(即,您在其中有".“符号)而不是查询表达式。
https://stackoverflow.com/questions/3887188
复制相似问题