![](/img/trans.png)
[英]What is the equivalent code of SQL query in C# with linq to datatable?
[英]C# code for equivalent LINQ query
我有以下 LINQ 查询,并想知道它的等效普通 C# 代码。
int[] arrayMain = new int[6];
return (from i in Enumerable.Range(0, arrayMain.Length / 2)
from c in ReturnArrayOfLengthTwo()
select c).ToArray();
这个查询的输出是一个长度为 6 的数组。但我想知道排序,因为 ReturnArrayOfLengthTwo 只是从 arrayMain 中选择两个随机位置,然后创建并返回一个长度为 2 的数组。
谢谢
那么它会是这样的:
var list = new List<int>();
for (int i = 0; i <= arrayMain.Length / 2; i++)
foreach (int j in ReturnArrayOfLengthTwo())
list.Add(j);
return list.ToArray();
我希望我理解你正确。
在非常基本的 C# 中(没有 LINQ、泛型、扩展方法等),它看起来像:
int[] arrayMain = new int[6];
// Filling the arrayMain with two elements, so increment i by 2
// arrayMain[0], arrayMain[1] (first loop)
// arrayMain[2], arrayMain[3] (second loop)
// arrayMain[4], arrayMain[5] (third loop)
for (int i = 0; i < arrayMain.Length - 1; i += 2)
{
// Returns two elements to insert into the arrayMain array.
int[] returnedArray = ReturnArrayOfLengthTwo();
arrayMain[i] = returnedArray[0];
arrayMain[i + 1] = returnedArray[1];
}
简单地说, ReturnArrayOfLengthTwo
显然返回两个元素放入数组。 因此,您只需遍历循环 3 次而不是 6 次,即可将所有需要的值放入arrayMain
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.