public List<Employeees> autoSuggestemployeee(string keyword,long employeeeTypeID,int count){ return context.Employeees.Where( x => x.Employeeename.Contains(keyword) && x.EmployeeeTypeID == employeeeTypeID) .Take(count).ToList();}
我有另一个Employeees集合,比如“BadEmployeees”,我想要的是使用相同的先前方法返回除“BadEmployeees”之外的所有Employeees.
我试着像这样写:
return context.Employeees.Where( x => x.Employeeename.Contains(keyword) && x.EmployeeeTypeID == employeeeTypeID) .Except(BadEmployeees).Take(count).ToList();
但它提供了一个例外,即Except可以使用Int,GuID等数据类型……
解决方法 如果您很乐意检索所有数据然后执行“除外”,则相对容易:return context.Employees .Where(x => x.Employeename.Contains(keyword) && x.EmployeeTypeID == employeeeTypeID) // limit the data *somewhat* .Take(count + BadEmployees.Count) // Do the rest of the query in-process .AsEnumerable() .Except(BadEmployees) .Take(count) .ToList();
或者:
// I'm making some assumptions about property names here...var badEmployeeIDs = badEmployees.Select(x => x.EmployeeID) .ToList();return context.Employees .Where(x => x.Employeename.Contains(keyword) && x.EmployeeTypeID == employeeeTypeID) && !badEmployeeIDs.Contains(x.EmployeeID)) .Take(count) .ToList();总结
以上是内存溢出为你收集整理的c# – 使用linq加载除另一个集合之外的集合全部内容,希望文章能够帮你解决c# – 使用linq加载除另一个集合之外的集合所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)