作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何以方法语法形式执行此操作:
foreach (var o in from o in orders
from oi in o.OrderItems
where oi.ProductName == "Widgets"
select o.OrderID)
Console.WriteLine("{0}", o);
尝试过但不起作用:
foreach (var o in orders
.SelectMany(o => o.OrderItems, (o, oi) => new {<<idk what to put here>> })
.Where(oi => oi.ProductName == "Widget"))
{
Console.WriteLine("WIDGET: {0}", o.OrderID);
}
最后我使用了这段代码,它成功了!
foreach (var o in orders
.SelectMany(o => o.OrderItems, (o, oi) => new { o.OrderID, oi.ProductName })
.Where(oi => oi.ProductName == "Widgets"))
{
Console.WriteLine("{0}", o.OrderID);
}
最佳答案
方法语法如下:
orders.Where(o=>o.OrderItems.Any(oi=>oi.ProductName == "Widgets")).Select(o=>o.OrderID)
关于c# - 如何将连接两个对象的 LINQ 查询语法转换为方法语法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44450609/
我是一名优秀的程序员,十分优秀!