数据集asp.net中foreach到while循环的转换

本文关键字:while 循环 转换 foreach asp net 数据集 | 更新日期: 2023-09-27 18:01:09

如何在while循环中转换以下foreach循环

foreach (DataTable table in ds.Tables)
{
    foreach (DataRow row in table.Rows)
    {
        temp_data = temp_data + ................
    }
}

数据集asp.net中foreach到while循环的转换

您可以像这样使用集合的枚举器:

IEnumerator enum1 = ds.Tables.GetEnumerator();
while (enum1.MoveNext())
{
    IEnumerator enum2 = ((DataTable)enum1.Current).Rows.GetEnumerator();
    while (enum2.MoveNext())
    {
        temp_data = temp_data + ((DataRow)enum2.Current)[0];
    }
}

但我建议LINQ表达式:

string temp_data = (from DataTable dataTable in ds.Tables select dataTable)
    .SelectMany(o => from DataRow dataRow in o.Rows select dataRow[0])
    .Aggregate(string.Empty, (qs, q) => qs = qs + q);

Br,Márton