データベースへの 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 サイトの他の関連記事を参照してください。