ホームページ >データベース >mysql チュートリアル >DataTable を SQL Server データベースに効率的に挿入するにはどうすればよいですか?

DataTable を SQL Server データベースに効率的に挿入するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2025-01-07 22:40:46218ブラウズ

How to Efficiently Insert a DataTable into a SQL Server Database?

データベースへの DataTable のバッチ挿入を最適化します

大量のデータをデータベースに挿入する場合、行ごとの挿入は非効率的です。 バッチ挿入テクノロジを使用すると、パフォーマンスが大幅に向上します。

SqlBulkCopy は効率的なデータ挿入を実装します

SQL Server データベースの場合、SqlBulkCopy クラスは、1 回の操作でデータベースに DataTable を挿入する効率的な方法を提供します。この方法により、行ごとの挿入が回避され、処理時間が大幅に短縮されます。

コード例

次のコードは、SqlBulkCopy の使用方法を示しています。

<code class="language-csharp">using (var bulkCopy = new SqlBulkCopy(_connection.ConnectionString, SqlBulkCopyOptions.KeepIdentity))
{
    // 将DataTable列映射到SQL表列
    foreach (DataColumn col in table.Columns)
    {
        bulkCopy.ColumnMappings.Add(col.ColumnName, col.ColumnName);
    }

    // 设置目标表名
    bulkCopy.DestinationTableName = destinationTableName;

    // 设置超时时间(可选)
    bulkCopy.BulkCopyTimeout = 600;

    // 将DataTable插入数据库
    bulkCopy.WriteToServer(table);
}</code>

カスタムマッピング (オプション)

DataTable の列名が SQL テーブルの列名と一致しない場合は、SqlBulkCopy の ColumnMappings プロパティを使用して手動でマップできます。

以上がDataTable を SQL Server データベースに効率的に挿入するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。