您好我正在使用实体框架和LinQ。我有一个名为users的表对象。我有一个名为userids的列表。我必须找到字符串中包含id的所有用户。我必须做以下操作......
select * from users where userid in (userids);
我试着像这样解决这个问题
var u = context.users.Where(o=> usersid.Contains(o=> o.userid)).Select(o=> o);
但它给出了编译错误。怎么解决这个?
答案 0 :(得分:1)
用句号代替逗号。
尝试
var u = context.users.Where(o=> usersid.Contains(o=> o.userid)).Select(o=> o);
答案 1 :(得分:0)
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);
确保您使用的是.
而不是,
,并确保您的方法具有正确的大小写。
答案 2 :(得分:0)
尝试使用它:
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();
这将解决您的问题。
答案 3 :(得分:0)
假设userids是与IEnumerable
类型相同的User.userid
,请尝试将LINQ查询更改为:
var u = context.users.Where(o=> userids.Contains(o.userid));