首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >实体框架。SQL Group By to EF Group By

实体框架。SQL Group By to EF Group By
EN

Stack Overflow用户
提问于 2012-03-29 21:48:40
回答 1查看 4.1K关注 0票数 5

我正在尝试定义一种按年、按月、按天、按小时等分组的标准方法……

通过阅读一些SQL文档,似乎最有效的方法是使用:

代码语言:javascript
复制
GROUP BY dateadd(month, datediff(month, 0, CreatedDate), 0)

注意“月”,“年”,...

然后,我尝试使用以下命令进行复制:

代码语言:javascript
复制
.GroupBy(x => SqlFunctions.DateAdd("month", SqlFunctions.DateDiff("month", 0, x.Created), 0))

.GroupBy(x => EntityFunctions.AddMonths(EntityFunctions.DiffMonths(0, x.Created)))

但是,这两个表达式都无法编译...

我不确定这是否是做这件事的方法?

如何在EF中正确复制SQL代码行?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-03-29 21:54:24

我不明白你为什么要使用标准的sql来做这件事,但是使用LINQ可以很容易地做到这一点,而且它会更标准,例如按匿名类型分组,例如:

代码语言:javascript
复制
.GroupBy( x => new 
               {
                  month = x.CreatedDate.Month,
                  year = x.CreatedDate.Year,
                  ...
               });
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9926703

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档