24

我正在尝试使用 C# 将一列插入到现有的 DataSet 中。

例如,我有一个 DataSet 定义如下:

DataSet ds = new DataSet();
ds.Tables.Add(new DataTable());
ds.Tables[0].Columns.Add("column_1", typeof(string));
ds.Tables[0].Columns.Add("column_2", typeof(int));
ds.Tables[0].Columns.Add("column_4", typeof(string));

稍后在我的代码中,我想在第 2 列和第 4 列之间插入一列。

DataSets 有添加列的方法,但我似乎无法找到插入列的最佳方法。

我想写一些类似下面的东西......

...Columns.InsertAfter("column_2", "column_3", typeof(string))

最终结果应该是一个包含以下列的表的数据集:column_1 column_2 column_3 column_4

而不是: column_1 column_2 column_4 column_3 这是 add 方法给我的

当然必须有一种方法来做这样的事情。

编辑...只是想根据以下一些评论澄清我对 DataSet 所做的事情:

我正在从存储过程中获取数据集。然后我必须向数据集添加额外的列,然后将其转换为 Excel 文档。我无法控制存储过程返回的数据,所以我必须在事后添加列。

4

4 回答 4

45

为此,您可以使用DataColumn.SetOrdinal()方法。

DataSet ds = new DataSet();
ds.Tables.Add(new DataTable());
ds.Tables[0].Columns.Add("column_1", typeof(string));
ds.Tables[0].Columns.Add("column_2", typeof(int));
ds.Tables[0].Columns.Add("column_4", typeof(string));
ds.Tables[0].Columns.Add("column_3", typeof(string));
//set column 3 to be before column 4
ds.Tables[0].Columns[3].SetOrdinal(2);
于 2008-12-09T02:40:39.537 回答
8

我使用您的建议为 DataSet 的 DataColumnCollection 创建了一个扩展方法:

public static void InsertAfter(this DataColumnCollection columns, 
                              DataColumn currentColumn, DataColumn newColumn)
{
    if (!columns.Contains(currentColumn.ColumnName))
       throw new ArgumentException(/** snip **/);

    columns.Add(newColumn);
    //add the new column after the current one
    columns[newColumn.ColumnName].SetOrdinal(currentColumn.Ordinal + 1); 
}

我现在可以写:

 dt = ds.Tables[0];
 dt.Columns.InsertAfter(dt.Columns["column_2"], new DataColumn("column_3"));
于 2008-12-09T04:40:56.783 回答
0

基于https://stackoverflow.com/a/17372008/492336,我使用 SetOrdinal 和 IndexOf() 在bar之前插入foo

table.Columns.Add("bar").SetOrdinal(table.Columns.IndexOf("foo"));

foo在添加后插入它+1

table.Columns.Add("bar").SetOrdinal(table.Columns.IndexOf("foo")+1);
于 2016-10-12T06:53:17.153 回答
-1

将前两列复制到新数据集中,然后添加第三列,然后添加其余列。

如有必要,您可以将其包装在 InsertAfter 函数中。

于 2008-12-09T01:57:59.093 回答