ホームページ >データベース >mysql チュートリアル >SqlBulkCopy を使用してリストから大規模なデータセットを効率的に挿入する方法

SqlBulkCopy を使用してリストから大規模なデータセットを効率的に挿入する方法

Patricia Arquette
Patricia Arquetteオリジナル
2024-12-30 01:04:10498ブラウズ

How to Efficiently Insert Large Datasets from a List using SqlBulkCopy?

リストからの一括データ挿入<> SqlBulkCopy の使用

質問: リストから大量のレコードを効率的に挿入する方法<> 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

ObjectReader を使用すると、非汎用データ ソースを操作し、メンバー名を動的に決定できます。ただし、メンバー名を事前に指定するとパフォーマンスが向上します。さらに、SqlBulkCopy の ColumnMappings 機能を利用して、列マッピングをカスタマイズできます。

以上がSqlBulkCopy を使用してリストから大規模なデータセットを効率的に挿入する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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