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

时间:2015-05-14 15:12:19

标签: c# linq entity-framework

在LINQ中,我想跟随查询:

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

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

  

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

我如何解决这个问题?

修改

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

4 个答案:

答案 0 :(得分:5)

试试这个

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

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

您获得的异常是因为Convert.ToDateTime是一种无法转换为SQL的.NET方法。通常这应该在查询生效后(即在.ToList()之前使用Where)完成,但在您的特定情况下,这是不必要的,因为DateTime对象可以使用{{1}进行比较}和>=和Entity Framework可以将其成功转换为SQL

现在,如果您只想比较Datetime的Date部分,可以使用位于<=命名空间内的方法DbFunctions.TruncateTime()。此方法将允许EF在SQL

中正确截断日期

答案 1 :(得分:1)

如果您想在两个日期之间获取实体,请按日期进行比较:

var result = content.Table.Where(x => x.date >= startDate
                                 && x.date <= endDate)
                           .ToList();

其中startDateendDate都是DateTime

转换为字符串意味着您受当前文化(区域设置)设置的支配。使用不变文化时,默认日期格式为美式,因此它们不会在字典上与任何有用的意义进行比较。

答案 2 :(得分:0)

使用AsEnumerable()返回结果,然后将其转换为list。

它将起作用我面临同样的问题,因为这个解决方案可能有用。

答案 3 :(得分:0)

使用DbFunctions.CreateDateTime(2019,1,28,0,0,0)