包含在linq查询中 [英] contains in linq query

查看:107
本文介绍了包含在linq查询中的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用实体框架和LinQ.我有一个名为users的表对象.我有一个名为userids的列表.我必须找到字符串中包含id的所有用户.我必须执行以下操作...

Hi i am using entity framework and LinQ. I have a table objects called users . i have a list called userids. i have to find all users where ids contains in the string. I have to do following operations ...

select * from users where userid in (userids);

我试图这样解决

var u = context.users.Where(o=> usersid.Contains(o=> o.userid)).Select(o=> o);

但是它给出了编译错误.该如何解决?

but it gives compilation error. how to solve this ?

推荐答案

尝试使用此方法:

protected 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();

            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);
}

调用这样的方法:

var u = context.users.Where(BuildContainsExpression<user, Int32>(e => e.Userid, userids)).ToList();

这将解决您的问题.

这篇关于包含在linq查询中的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆