24

C#を使用して既存のデータセットに列を挿入しようとしています。

例として、次のように定義された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の間に列を挿入したいと思います。

データセットには列を追加するためのメソッドがありますが、列を挿入するための最良の方法を見つけることができないようです。

次のようなものを書きたいのですが…

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

最終結果は、次の列を持つテーブルを持つデータセットになります。column_1column_2 column_3 column_4

ではなく:column_1 column_2column_4column_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 に答える
-1

最初の2つの列を新しいデータセットにコピーしてから、3番目の列を追加し、残りの列を追加します。

必要に応じて、これをInsertAfter関数でラップできます。

于 2008-12-09T01:57:59.093 に答える