首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >linq to entities,像WhereAnyIn这样的运算符?

linq to entities,像WhereAnyIn这样的运算符?
EN

Stack Overflow用户
提问于 2009-12-01 11:59:20
回答 1查看 133关注 0票数 1

我以前见过whereIn的实现。但我想知道谁能教我写一篇操作词"WhereAnyIn“。

例如: Ive an entities: Post - PostTag - Tag

我需要一个带有参数int[]标签I的查询,其中获取所有在给定列表中具有任何标签I的帖子。

我想不出来。

谢谢你的帮助。

EN

回答 1

Stack Overflow用户

发布于 2011-02-24 02:23:22

代码语言:javascript
复制
    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;
    }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1823916

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档