linq-to-sql объединяет дочерние выражения - PullRequest
1 голос
/ 31 марта 2010

Мне нужно создать и объединить несколько выражений для дочерней сущности в одно, чтобы использовать его в операторе «Любой» родителя. Код теперь выглядит так:

Expresion<Child, bool> startDateExpression;

if(String.IsNullOrEmpty(startDate)
     startDateExpression = t => true;
else
     startDateExpression = t => t.start_date >= startDate;

Expression<Child, bool> endDateExpression;

if(String.IsNullOrEmpty(endDate)
     endDateExpression = t => true;
else
     endDateExpression = t => t => t.end_date <= endDate;


....
ParameterExpression param = startDateExpression.Parameters[0];

Expression<Func<T, bool>> Combined = Expression.Lambda<Func<Child, bool>>( 
        Expression.AndAlso(startDateExpression.Body, endDateExpression.Body), param);

//but now I am trying to use combined expression on parent 
//this line fails just to give an idea on what I am trying to do:
//filter type is IQueryable<Parent>;
var filter = filter.Where(p =>p.Children.Any(Combined));

Как я могу это сделать? Есть ли лучший (более элегантный способ сделать это? Может быть, я должен преобразовать дочернее выражение в родительское выражение?

1 Ответ

0 голосов
/ 31 марта 2010

Я не совсем уверен, почему вы строите выражения вместо использования лямбда-функций. Вы пробовали следующее?

var filter = filter.Where(p =>p.Children.Any(
   child => (String.IsNullOrEmpty(startDate) || child.start_date >= startDate) &&
            (String.IsNullOrEmpty(endDate) || child.end_date <= endDate)
));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...