我有这种搜索方法:
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();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。