我正在尝试定义一种按年、按月、按天、按小时等分组的标准方法……
通过阅读一些SQL文档,似乎最有效的方法是使用:
GROUP BY dateadd(month, datediff(month, 0, CreatedDate), 0)注意“月”,“年”,...
然后,我尝试使用以下命令进行复制:
.GroupBy(x => SqlFunctions.DateAdd("month", SqlFunctions.DateDiff("month", 0, x.Created), 0))
.GroupBy(x => EntityFunctions.AddMonths(EntityFunctions.DiffMonths(0, x.Created)))但是,这两个表达式都无法编译...
我不确定这是否是做这件事的方法?
如何在EF中正确复制SQL代码行?
发布于 2012-03-29 21:54:24
我不明白你为什么要使用标准的sql来做这件事,但是使用LINQ可以很容易地做到这一点,而且它会更标准,例如按匿名类型分组,例如:
.GroupBy( x => new
{
month = x.CreatedDate.Month,
year = x.CreatedDate.Year,
...
});https://stackoverflow.com/questions/9926703
复制相似问题