ホームページ > データベース > mysql チュートリアル > SqlBulkCopy は DataTable データベースの挿入をどのように最適化できますか?

SqlBulkCopy は DataTable データベースの挿入をどのように最適化できますか?

Susan Sarandon
リリース: 2025-01-08 00:36:43
オリジナル
708 人が閲覧しました

How Can SqlBulkCopy Optimize DataTable Database Inserts?

SqlBulkCopy による DataTable データベース挿入の高速化

大規模なデータセットを 1 行ずつデータベースに挿入すると、時間がかかることで有名です。 この記事では、SqlBulkCopy を使用して DataTable 全体を一度に挿入する、より効率的な方法を示します。

SqlBulkCopy: パフォーマンス向上のための一括データ挿入

.NET System.Data.SqlClient 名前空間内のクラスである SqlBulkCopy を使用すると、高速の一括データ挿入が可能になります。 データ転送を最適化し、データベースの相互作用を最小限に抑えることで、個々の行の挿入よりもパフォーマンスが大幅に向上します。

実装: 実用的な例

SqlBulkCopy を使用するには、データベース接続と適切に構成された SqlBulkCopy オブジェクトが必要です。 次のコード スニペットはプロセスを示しています:

<code class="language-csharp">using (var bulkCopy = new SqlBulkCopy(_connection.ConnectionString, SqlBulkCopyOptions.KeepIdentity))
{
    // Assumes DataTable and SQL table columns have matching names.
    foreach (DataColumn col in table.Columns)
    {
        bulkCopy.ColumnMappings.Add(col.ColumnName, col.ColumnName);
    }

    bulkCopy.BulkCopyTimeout = 600; // Timeout in seconds
    bulkCopy.DestinationTableName = destinationTableName;
    bulkCopy.WriteToServer(table);
}</code>
ログイン後にコピー

列マッピングの不一致への対処

上記の例では、DataTable と SQL テーブルの列名が同一であると想定しています。 そうでない場合は、正確なデータ挿入を保証するために ColumnMappings コレクション内で列マッピングを明示的に定義する必要があります。

この方法は、ターゲット SQL テーブルよりも列が少ない大規模なデータセットを挿入する場合に特に有益であることがわかります。 一致しない列は自動的にデフォルトの NULL 値になります。 SqlBulkCopy を採用すると、DataTable 挿入のパフォーマンスが大幅に向上し、行ごとの反復メソッドのパフォーマンスのボトルネックが回避されます。

以上がSqlBulkCopy は DataTable データベースの挿入をどのように最適化できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート