我被困在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)));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。