如何打印datareader中的所有列

时间:2010-04-29 15:44:50

标签: c# ado.net datareader

使用c#如何打印datareader中的所有列。

3 个答案:

答案 0 :(得分:28)

当传递datareader时,此方法将返回一个可列出的列名列表:

static List<string> GetDataReaderColumnNames(IDataReader rdr)
{
    var columnNames = new List<string>();
    for (int i = 0; i < rdr.FieldCount; i++)
        columnNames.Add(rdr.GetName(i));
    return columnNames;
}

答案 1 :(得分:11)

要为答案添加一些值,我添加了一个可能的扩展方法来返回给定DataReader的列名。

public static IEnumerable<string> GetColumnNames(this IDataReader reader)
{
    for(int i=0; i<reader.FieldCount; i++)
        yield return reader.GetName(i);
}

答案 2 :(得分:3)

for (int j = 0; j < x.VisibleFieldCount; j++)
            Console.WriteLine(x.GetName(j));