Манипуляция DateTime внутри запроса Linq to entities
запуск этого кода:
public bool CheckTime(DateTime date, int UserID, int TotalTimeMin)
        {
            using (var context = new myDB())
            {         
                var assginments = from c in context.Assignments.Where(x=>(x.AssignmentDateTime < date && x.AssignmentDateTime.Value.AddMinutes(TotalTimeMin) > date) || 
                    (x.AssignmentDateTime < date.AddMinutes(TotalTimeMin))) select c;
                if(assginments != null) return false;
                else return true;
            }
        }
Я получаю эту ошибку.
LINQ to Entities does not recognize the method 'System.DateTime AddMinutes(Double)' method, and this method cannot be translated into a store expression.
TotalTimeMin является int. Я не уверен, что причина этого: AssignmentDateTime-это DateTime? может, в этом и проблема ?
1 ответов
использовать EntityFunctions.AddMinutes (требуется EF 4):
    public bool CheckTime(DateTime date, int UserID, int TotalTimeMin)
    {
        using (var context = new myDB())
        {         
            var assginments = context.Assignments
                                     .Where(x=>(x.AssignmentDateTime < date 
                                                && EntityFunctions.AddMinutes(x.AssignmentDateTime,TotalTimeMin) > date) 
                                                || (x.AssignmentDateTime < date.AddMinutes(TotalTimeMin)));
            if(assginments != null) return false;
            else return true;
        }
    }
отметим, что assignments будет никогда быть null (но он может быть пустым -- test assignments.Any()).
