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

时间:2015-07-06 12:19:03

标签: c# asp.net dataset

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

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

1 个答案:

答案 0 :(得分:1)

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

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, 马顿