c# – LINQ to Entities无法识别方法’System.DateTime ToDateTime(System.String)’

在LINQ中我想要跟随查询:
_tareaRepositorio.ObtenerTodo()
  .Where(
   x =>
     Convert.ToDateTime(x.FechaCreacion.ToString("d")) >= fechaInicial &&
     Convert.ToDateTime(x.FechaCreacion.ToString("d")) <= fechaFinal).ToList();

但是,在执行时,查询出现以下错误:

LINQ to Entities does not recognize the method ‘System.DateTime ToDateTime(System.String)’ method,and this method cannot be translated into a store expression.

我怎么解决这个问题?

编辑

麻烦的是我需要比较日期,而不是时间……

解决方法

试试这个

编辑:添加DbFunctions.TruncateTime()以获得所需的效果

_tareaRepositorio.ObtenerTodo()
    .Where( x => DbFunctions.TruncateTime(x.FechaCreacion) >= fechaInicial &&
                 DbFunctions.TruncateTime(x.FechaCreacion) <= fechaFinal)
    .ToList();

您获得的异常是因为Convert.ToDateTime是一个无法转换为SQL的.NET方法.通常这应该在查询实现之后完成(即在Where之前使用.ToList())但在特定情况下它是不必要的,因为可以使用> =和< =来比较DateTime对象,并且实体框架可以转换它到SQL成功 现在,如果您只想比较Datetime的Date部分,可以使用位于System.Data.Entity命名空间内的方法DbFunctions.TruncateTime().此方法将允许EF在SQL中正确截断日期

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...