首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用Entity Framework仅按日期计算行,不计算时间

使用Entity Framework仅按日期计算行,不计算时间
EN

Stack Overflow用户
提问于 2018-07-01 00:28:24
回答 2查看 89关注 0票数 0

仔细检查CountEmailChart。在这里,我接受DateTime的输入,这是完全格式化的日期和时间。但问题是,我只想比较下面Entity Framework上的日期,而不是时间,以计算行数。有人能告诉我怎么做吗?

控制器代码:

代码语言:javascript
复制
public int CountEmailChart(DateTime date, int campaignID)
{
    int count = dbcontext.CampaignEmails
                         .Count(x => x.DateSigned == date && x.CampaignID == campaignID);
    return count;
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-07-01 00:35:48

试着这样做。DateTime对象的.Date属性将仅返回日期部分。

如果你使用Entity Framework6,那么。

代码语言:javascript
复制
date = date.Date;
int count = dbcontext.CampaignEmails.Count(x => DbFunctions.TruncateTime(x.DateSigned) == date.Date && x.CampaignID == campaignID);

否则

代码语言:javascript
复制
date = date.Date;
int count = dbcontext.CampaignEmails.Count(x => EntityFunctions.TruncateTime(x.DateSigned) == date.Date && x.CampaignID == campaignID);
票数 0
EN

Stack Overflow用户

发布于 2018-07-01 02:49:31

卡兰的答案是正确的,但是结果查询不会使用DateSigned的索引。如果存在这样的索引(或者CampaignID和DateSigned列的组合索引),您可能更喜欢这种方法:

代码语言:javascript
复制
var startDate = date.Date;
var endDate = date.Date.AddDay(1);
int count = dbcontext.CampaignEmails.Count(x => x.CampaignID == campaignID && x.DateSigned >= startDate && x.DateSigned < endDate);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51116624

复制
相关文章

相似问题

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