3

空でない datatable があります。1 から始まる連番を持つ別の列を追加する最良の方法は何ですか?

次のコードを試しました。しかし、うまくいきませんでした。

DataColumn dc = new DataColumn("Col1");
dc.AutoIncrement = true;
dc.AutoIncrementSeed = 1;
dc.AutoIncrementStep = 1;       
dc.DataType = typeof(Int32);
dt.Columns.Add(dc);

このシナリオで式を設定すると役立ちますか?

前もって感謝します

4

3 に答える 3

8

自動インクリメント フィールドのみを含む 2 番目の「ヘルパー」データ テーブルを使用して、次のような既存のデータを入力/マージすることで、それを達成できると思います。

DataTable dtIncremented  = new DataTable(dt.TableName);
DataColumn dc            = new DataColumn("Col1");
dc.AutoIncrement         = true;
dc.AutoIncrementSeed     = 1;
dc.AutoIncrementStep     = 1;
dc.DataType              = typeof(Int32);    
dtIncremented.Columns.Add(dc);

dtIncremented.BeginLoadData();

DataTableReader dtReader = new DataTableReader(dt);
dtIncremented.Load(dtReader);

dtIncremented.EndLoadData();

そして、元の dt の代わりに dtIncremented テーブルを返すだけです。エレガントなソリューションではありませんが、うまくいくはずです。

于 2010-11-30T05:57:32.790 に答える
1

以下のコードは私のために働いた

コードが編集される

        // Added temp rows so that this solution can mimic actual requirement

        DataTable dt = new DataTable();
        DataColumn dc1 = new DataColumn("Col");
        dt.Columns.Add(dc1);

        for(int i=0;i<10;i++)
        {
            DataRow dr = dt.NewRow();
             dr["Col"] = i.ToString();
             dt.Rows.Add(dr);
        }


        // Added new column with Autoincrement, 

        DataColumn dc = new DataColumn("Col1"); 
        dc.AutoIncrement = true;
        dc.AutoIncrementSeed = 1;
        dc.DataType = typeof(Int32);

        // Handeled CollectionChanged event

        dt.Columns.CollectionChanged += new CollectionChangeEventHandler(Columns_CollectionChanged);
        dt.Columns.Add(dc);

        // After column added demostratation

        DataRow dr1 = dt.NewRow();
            dt.Rows.Add(dr1);



    void Columns_CollectionChanged(object sender, CollectionChangeEventArgs e)
    {
        DataColumn dc = (e.Element as DataColumn);
        if (dc != null && dc.AutoIncrement)
        {
            long i = dc.AutoIncrementSeed;
            foreach (DataRow drow in dc.Table.Rows)
            {
                drow[dc] = i;
                i++;
            }
        }
    }
于 2010-11-30T05:30:45.467 に答える
0

このためにまったく新しいデータテーブルを作成し、古いテーブルから新しいテーブルに各行を 1 つずつ手動でディープ コピーする必要があります。ごめん。

于 2010-11-30T05:29:11.217 に答える