我有一个项目列表和一个 LINQ 查询。现在,使用 LINQ 的延迟执行,后续的 foreach 循环是只执行一次查询还是在循环中的每个回合执行一次?
鉴于此示例(取自MSDN 上的 Introduction to LINQ Queries (C#))
// The Three Parts of a LINQ Query:
// 1. Data source.
int[] numbers = new int[7] { 0, 1, 2, 3, 4, 5, 6 };
// 2. Query creation.
// numQuery is an IEnumerable<int>
var numQuery =
from num in numbers
where (num % 2) == 0
select num;
// 3. Query execution.
foreach (int num in numQuery)
{
Console.Write("{0,1} ", num);
}
或者,换句话说,如果我有,会有什么不同:
foreach (int num in numQuery.ToList())
而且,如果底层数据不在数组中,而是在数据库中,这有关系吗?