[英]Linq Intersect Comma Delimited String with List Containing Strings Any & All
[英]Linq Intersect Comma Delimited String with List Containing Strings using Iqueriable
resultList is an IQueriable<foo>
用作具有过滤选项的网格的结果。 这些过滤器之一是项目过滤器。
foo.projects
是一个字符串,它是由用逗号分隔的项目组成的字符串,例如:
foo.projects = "project1,project2,project3";
filterProjects是一个List<string>
使用此代码过滤成功,但是由于我使用的是ToList(),因此resultList不能再作为IQueriable用于分页。
resultList = resultList.Where(x => (x.projects.Split(',').ToList().Intersect(filterProjects).Count() > 0));
我的问题是:可以在将resultList保持为IQueriable
同时进行此操作(不使用ToList()
)吗?
尝试这个
resultList.Where(x => x.Projects.Split(',').Any(p => filterProjects.Any(fp => fp == p)))
更新
正如Mihai Labo指出的那样,这在LINQ to Entities上不起作用,因为Split()无法转换为商店表达式。
假设过滤器名称不相互包含(请参见注释),则可以将解决方案重新设计(以在LINQ to Entities上工作),方法如下:
resultList.Where(x => filterProjects.Any(fp => x.Projects.Contains(fp)))
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.