LINQ to Entities无法识别方法'System.DateTime ToDateTime(System.String)'

Fre*_*ias 6 c# linq entity-framework

在LINQ中我想要跟随查询:

_tareaRepositorio.ObtenerTodo()
  .Where(
   x =>
     Convert.ToDateTime(x.FechaCreacion.ToString("d")) >= fechaInicial &&
     Convert.ToDateTime(x.FechaCreacion.ToString("d")) <= fechaFinal).ToList();
Run Code Online (Sandbox Code Playgroud)

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

LINQ to Entities无法识别方法'System.DateTime ToDateTime(System.String)'方法,并且此方法无法转换为商店表达式.

我怎么解决这个问题?

编辑

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

Car*_*ñoz 5

试试这个

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

_tareaRepositorio.ObtenerTodo()
    .Where( x => DbFunctions.TruncateTime(x.FechaCreacion) >= fechaInicial &&
                 DbFunctions.TruncateTime(x.FechaCreacion) <= fechaFinal)
    .ToList();
Run Code Online (Sandbox Code Playgroud)

您获得的异常是因为它Convert.ToDateTime是一个无法转换为SQL的.NET方法.通常这应该在查询实现之后(即.ToList()在之前使用Where)完成,但在您的特定情况下,它是不必要的,因为DateTime可以使用>=和比较对象,<=并且实体框架可以将其成功转换为SQL

现在,如果您只想比较Datetime的Date部分,可以使用命名空间DbFunctions.TruncateTime()内的方法System.Data.Entity.此方法将允许EF在SQL中正确截断日期