C# 如何将列插入到两个现有列之间的数据集中?

C# 如何将列插入到两个现有列之间的数据集中?,c#,insert,dataset,C#,Insert,Dataset,我正在尝试使用C#将列插入现有数据集中 例如,我有一个定义如下的数据集: 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(stri

我正在尝试使用C#将列插入现有数据集中

例如,我有一个定义如下的数据集:

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列之间插入一列

数据集有添加列的方法,但我似乎找不到插入列的最佳方法

我想写一些如下的东西

...Columns.InsertAfter("column_2", "column_3", typeof(string))
最终结果应该是一个具有以下列的表的数据集: 第1列第2列第3列第4列

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

肯定有办法做到这一点

编辑…我只是想根据下面的一些评论澄清我对数据集做了什么:


我正在从存储的 程序然后我要补充一点 数据集的其他列 然后将其转换为Excel 文件。我没有控制权 存储过程返回的数据 所以我必须在 事实


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

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

您可以使用该方法实现此目的

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);

我根据您的建议为数据集的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"));
基于,我使用带有IndexOf()的SetOrdinal在
foo
之前插入
bar

table.Columns.Add("bar").SetOrdinal(table.Columns.IndexOf("foo"));
要在
foo
之后插入它,只需添加
+1

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

只是出于好奇,你为什么要这么做?数据库代码依赖于存储列的顺序通常不是一个好主意。我从存储过程中获取数据集。然后,我必须向数据集中添加其他列,然后将这些列转换为Excel文档。我无法控制存储过程返回的数据,因此我必须在事实发生后添加列。我已经在那里了。有时候你只需要写一篇文章。通常,因为你的老板要求。