c# – 如何从LINQ获取IEnumerable而不是IEnumerable?

前端之家收集整理的这篇文章主要介绍了c# – 如何从LINQ获取IEnumerable而不是IEnumerable?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我被困在LINQ查询中,我试图使用EntityFramework 6从sql表返回列表记录,而不是获取该列表,我最终得到一个IEnumerable< string []&gt ;. 这是我为获得IEnumerable< string []>所做的.我在表中有一个列需要拆分,然后我测试一下列表是否包含这些字符串:表列columnOne中的值可能是这样的“ab”或“bc”等,因此需要使用这个s.columnOne.Split(‘ – ‘)
list<string> checkList = new list<string>();
checkList.add("a")
checkList.add("b")
checkList.add("c")

List<Foo> fooList = dbContext.Foos.ToList();

IEnumerable<string[]> items = fooList.Select(s => s.columnOne.Split('-'));

var result = items.SelectMany(x => x)
                  .Where(s => checkList.Contains(s)).ToList();

上面的工作原理应该如此,但最后它返回一个字符串列表,这不是我需要的.

我试过这个:

List<Foo> fooList = dbContext.Foos.ToList();

var test = fooList.Where(s => s.columnOne.Split('-'));

这就是我遇到错误的地方,因为我最终试图返回< Foo>列表而不是< string>

现在我知道Where子句需要返回一个bool值,例如fooList.Where(s => s.columnOne ==“someString”);,但我对如何构建LINQ查询感到茫然得到我想要的结果.

任何正确方向的推动都会很棒.

解决方法

where子句需要包含对checkList的检查
var test = fooList.Where(foo => foo.columnOne.Split('-').Any(str => checkList.Contains(str)));

猜你在找的C#相关文章