繁体   English   中英

Linq与逗号分隔的字符串相交,列表中包含使用不可变的字符串

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM