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

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

Patricia Arquette
リリース: 2024-12-30 01:04:10
オリジナル
464 人が閲覧しました

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

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