Как настроить перевод с ESQL на T-SQL в Entity Framework v1.0 - PullRequest
0 голосов
/ 07 сентября 2011

Поскольку EF v1 не поддерживает "IN", мне интересно, есть ли способ расширить суть сущности, чтобы мы могли поддерживать оператор "IN" в EF v1.0.

1 Ответ

1 голос
/ 07 сентября 2011

Вот решение, представленное на форумах MSDN.

static Expression<Func<TElement, bool>> BuildContainsExpression<TElement, TValue>(
    Expression<Func<TElement, TValue>> valueSelector, IEnumerable<TValue> values)
{
    if (null == valueSelector) { throw new ArgumentNullException("valueSelector"); }
    if (null == values) { throw new ArgumentNullException("values"); }
    ParameterExpression p = valueSelector.Parameters.Single();
    // p => valueSelector(p) == values[0] || valueSelector(p) == ...
    if (!values.Any())
    {
        return e => false;
    }
    var equals = values.Select(value => (Expression)Expression.Equal(valueSelector.Body, Expression.Constant(value, typeof(TValue))));
    var body = equals.Aggregate<Expression>((accumulate, equal) => Expression.Or(accumulate, equal));
    return Expression.Lambda<Func<TElement, bool>>(body, p);
}

Пожалуйста, пройдите ветку для подробного ответа

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...