对DataTable的SQL查询以包含标头

时间:2015-02-07 09:34:58

标签: c# sql sql-server datatable

到目前为止,我有一个实用程序类,其中包含一个名为" getTable"的函数,它接受了一个字符串查询并返回了一个数据表。现在我试图通过excel返回这些查询。简单地将数据表的内容复制到excel工作正常 - 但是电子表格上没有标题行来解释每列的内容。

以下是我的尝试:

public static DataTable getTable(String sql, bool includeHeaderRow)
    {
        DataTable table = new DataTable();
        using (SqlDataAdapter adpt = new SqlDataAdapter(sql, getConn()))
        {
            adpt.Fill(table);

            if (includeHeaderRow)
            {
                DataRow headerRow = table.NewRow();

                for (int i = 0; i < table.Columns.Count; i++)
                {
                    headerRow[i] = table.Columns[i].ColumnName;
                }

                table.Rows.InsertAt(headerRow, 0);
            }
        }
        return table;
    }

上面几乎可以工作,但是当我尝试将列名(显然是一个字符串)写入数据表的非字符串列时会抛出异常。

有任何想法可以轻松实现这一目标吗?

1 个答案:

答案 0 :(得分:2)

当然代码可能会出错,因为正如您所说的那样,将没有兼容的数据类型分配到具有特定数据类型的列中,如果您通过创建表的副本尝试change the column datatype to object,则Datatable中的列现在接受特定的数据类型(克隆它)我认为问题会解决:

public static DataTable getTable(String sql, bool includeHeaderRow)
    {
        DataTable table = new DataTable();
        using (SqlDataAdapter adpt = new SqlDataAdapter(sql, getConn()))
        {
            adpt.Fill(table);


            if (includeHeaderRow)
            {    
                DataTable dt = table.Clone();
                for (int i = 0; i < table.Columns.Count; i++)
                {
                  dt.Columns[i].DataType = typeof(Object);
                }
                foreach (DataRow row in table.Rows) 
                {
                   dt.ImportRow(row);
                }
                DataRow headerRow = dt.NewRow();
                for (int i = 0; i < table.Columns.Count; i++)
                {
                    headerRow[i] = table.Columns[i].ColumnName;
                }

                dt.Rows.InsertAt(headerRow, 0);
            }
        }
        return dt;
    }