c# – 如何从LINQ获取IEnumerable而不是IEnumerable?
发布时间:2020-12-15 08:32:58 所属栏目:百科 来源:网络整理
导读:我被困在LINQ查询中,我试图使用EntityFramework 6从SQL表返回列表记录,而不是获取该列表,我最终得到一个IEnumerable string []gt ;. 这是我为获得IEnumerable string []所做的.我在表中有一个列需要拆分,然后我测试一下列表是否包含这些字符串:表列columnOn
我被困在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))); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |