包含在 LINQ 查询中

本文关键字:查询 LINQ 包含 | 更新日期: 2023-09-27 18:17:09

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

select * from users where userid in (userids);

我试图像这样解决这个问题

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

但它给出了编译错误。 如何解决这个问题?

包含在 LINQ 查询中

用句点代替逗号。

尝试

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

尝试使用这个:

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

这将解决您的问题。

var u = context.users,Where(o=> usersid.contains(o=> o.userid)),select(o=> o);

假设这是您正在使用的代码

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

确保您使用的是.而不是,,并且您的方法具有正确的大小写。

假设用户 id 是与 User.userid 类型相同的IEnumerable,请尝试将 LINQ 查询更改为:

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