質問: リストから大量のレコードを効率的に挿入する方法<> SqlBulkCopy を使用して単純なオブジェクトを作成するには?
回答:
一括挿入を最適化するには、FastMember ライブラリの利用を検討してください。このアプローチでは、オブジェクト リストからデータを直接ストリーミングすることで、DataTable のオーバーヘッドを回避します。その方法は次のとおりです。
using(var bcp = new SqlBulkCopy(connection)) using(var reader = ObjectReader.Create(data, "Id", "Name", "Description")) { bcp.DestinationTableName = "SomeTable"; bcp.WriteToServer(reader); }
ObjectReader を使用すると、非汎用データ ソースを操作し、メンバー名を動的に決定できます。ただし、メンバー名を事前に指定するとパフォーマンスが向上します。さらに、SqlBulkCopy の ColumnMappings 機能を利用して、列マッピングをカスタマイズできます。
以上がSqlBulkCopy を使用してリストから大規模なデータセットを効率的に挿入する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。