【C#】データテーブルを別のデータテーブルにコピーする【DataTable】

構造体とデータも含めたコピーをする

「dt.Copy()」を使用します。

既にあるデータテーブルをコピーして、

構造体もデータも同じデータテーブルを作成します。


    // データテーブルの初期化
    DataTable dt = new DataTable();

    // データテーブルの名前を指定
    dt.TableName = "FRUIT";

    // 列追加
    dt.Columns.Add("HINMEI");
    dt.Columns.Add("SURYO");
    dt.Columns.Add("TANKA");
    dt.Columns.Add("KINGAKU");
    // 行追加
    dt.Rows.Add("りんご", "3", "50", "150");
    dt.Rows.Add("ぶどう", "1", "200", "200");
    dt.Rows.Add("みかん", "10", "30", "300");

    /* 
      今回の内容はここから
    */ 
    // 構造体とデータも含めたコピーをする
    DataTable dtCopy = new DataTable();
    dtCopy = dt.Copy();


コピペですぐ試せるソースコード

今回は、まとめる必要がありませんでしたが、メソッド形式のソースコードも記載したいので載せます。

ソースコードをコピペするとそれぞれの動作が確認できると思います。


        private void DataTable_Copy()
        {
            DataTable dt = new DataTable();

            // データテーブルの名前を指定
            dt.TableName = "FRUIT";

            // 列追加
            dt.Columns.Add("HINMEI");
            dt.Columns.Add("SURYO");
            dt.Columns.Add("TANKA");
            dt.Columns.Add("KINGAKU");
            // 行追加
            dt.Rows.Add("りんご", "3", "50", "150");
            dt.Rows.Add("ぶどう", "1", "200", "200");
            dt.Rows.Add("みかん", "10", "30", "300");

            /* 
              今回の内容はここから
            */ 
            // 構造体とデータも含めたコピーをする
            DataTable dtCopy = new DataTable();
            dtCopy = dt.Copy();
        }


まとめ

構造体とデータを含めて、別のデータテーブルを作る場合は、Copyを使う。

構造体だけをコピーして、別のデータテーブルを作る場合は、Cloneを使う。

用途にあったやり方、自分のやりやすい実装を採用していきましょう。


Microsoft 公式ページ

DataTable.Copy メソッド

https://docs.microsoft.com/ja-jp/dotnet/api/system.data.datatable.copy?view=netframework-4.0