实体框架获取当前日期行(当天的时间)

Posted

技术标签:

【中文标题】实体框架获取当前日期行(当天的时间)【英文标题】:Entity Framework Getting current date rows(while time in that day) 【发布时间】:2022-01-14 09:26:39 【问题描述】:

我有一张表,日期时间的值是这样的

2021-12-08 10:10:54.657
2021-12-08 10:10:41.567
2021-12-08 10:09:51.960
2021-12-08 10:10:54.657
2021-12-08 10:10:41.567
2021-12-08 10:09:51.960
2021-12-08 10:10:54.657

我想得到那一天或今天(现在是 2021 年 12 月 8 日)。所以我尝试在控制器中使用 EF:

 ViewBag.CByUserToday = _db.ArrayDatas.Where(a => a.CreatedBy == user && a.CreatedDate == DateTime.Today.Date).Count();

但我仍然没有得到这些行。当我尝试调试 DateTime.Today.Date 时,据说 DateTime.Today = 09/12/2021 00:00:00 。但是,当我尝试将 createddate 更新为 '2021-12-09 00:00:00.000' 时,它可以被检索到。 那么,如何检索我今天创建的行(忽略时间)?

【问题讨论】:

使用>< 【参考方案1】:

检查列是否大于或等于今天,小于明天:

DateTime today = DateTime.Today;
DateTime tomorrow = today.AddDays(1);
ViewBag.CByUserToday = _db.ArrayDatas
    .Where(a => a.CreatedBy == user 
             && a.CreatedDate >= today 
             && a.CreatedDate < tomorrow)
    .Count();

这样,您的 DBMS 将能够在 CreatedByCreatedDate 列上使用合适的索引来满足您的查询。

当您尝试过滤列时,通常最好避免在列上调用函数,因为这意味着查询不是SARGable。但是,根据this thread on DBA,将datetime/datetime2 列转换为date SARGable,至少在Microsoft SQL Server 中是这样。

【讨论】:

以上是关于实体框架获取当前日期行(当天的时间)的主要内容,如果未能解决你的问题,请参考以下文章

JS里面怎么获取当天日期

vb如何判断当天是不是是指定日期

javascript获取当天本周本月本年 开始及结束时间

java 获取当前日期,应该如何操作呢

根据当前日期+时间查询 JPA 实体以获取实例的最佳方法是啥?

sql如何取得当前日期