我被困在LINQ查询中,我试图使用EntityFramework 6从sql表返回列表记录,而不是获取该列表,我最终得到一个IEnumerable< string []> ;. 这是我为获得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)));