LINQ к сущностям, оператор, как WhereAnyIn? - PullRequest
1 голос
/ 01 декабря 2009

я видел где в реализации раньше. Но мне интересно, может кто-нибудь показать мне написать опцию "WhereAnyIn".

например: Ive лица: Post --- PostTag --- Tag

Мне нужен запрос с параметром int [] tagids, который извлекает все сообщения, в которых есть какой-либо из tagid. список.

Я не могу понять.

спасибо за вашу помощь.

1 Ответ

1 голос
/ 23 февраля 2011
    static void Main(string[] args)
    {
        int[] integers = Enumerable.Range(0, 10).ToArray();
        Expression<Func<Post, bool>> expression = CreateWhereInExpression<Post, int>(p => p.Tag, integers);
    }

    static Expression<Func<TItem, bool>> CreateWhereInExpression<TItem, TValue>(Expression<Func<TItem, TValue>> lambda, TValue[] items)
    {
        if (lambda != null)
        {
            MemberExpression memberExpression = lambda.Body as MemberExpression;
            if (memberExpression != null && memberExpression.Expression == lambda.Parameters[0])
            {
                Expression body;
                if (items == null || items.Length == 0)
                {
                    body = Expression.Constant(
                        true
                    );
                }
                else
                {
                    body = items.Skip(1).Aggregate(
                        Expression.Equal(
                            memberExpression,
                            Expression.Constant(items[0])
                        ),
                        (expression, item) => Expression.OrElse(
                            expression,
                            Expression.Equal(
                                memberExpression,
                                Expression.Constant(
                                    item
                                )
                            )
                        )
                    );
                }
                return Expression.Lambda<Func<TItem, bool>>(
                    body,
                    lambda.Parameters
                );
            }
        }
        return null;
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...