Frameurs de l'entité augmentant les performances d'insertion avec de grands ensembles de données
L'insertion de données à grande échelle dans Entity Framework peut conduire à des goulots d'étranglement de performances significatifs et des délais d'attente de transaction. Cet article décrit les stratégies pour optimiser ce processus.
Minimiser SaveChanges()
appels:
Les appels répétés à SaveChanges()
après chaque insertion réduisent considérablement l'efficacité. Au lieu de cela, utilisez ces techniques:
SaveChanges()
Une seule fois après tout les enregistrements sont ajoutés. SaveChanges()
à intervalles réguliers (par exemple, tous les 100 enregistrements). Exemple d'insert en vrac efficace:
Le code suivant démontre un modèle d'insertion en vrac haute performance:
<code class="language-csharp">using (TransactionScope scope = new TransactionScope()) { MyDbContext context = null; try { context = new MyDbContext(); context.Configuration.AutoDetectChangesEnabled = false; int count = 0; foreach (var entityToInsert in largeDataset) { ++count; context = AddToContext(context, entityToInsert, count, 100, true); } context.SaveChanges(); } finally { if (context != null) context.Dispose(); } scope.Complete(); } private MyDbContext AddToContext(MyDbContext context, Entity entity, int count, int batchSize, bool recycleContext) { context.Set<Entity>().Add(entity); if (count % batchSize == 0) { context.SaveChanges(); if (recycleContext) { context.Dispose(); context = new MyDbContext(); context.Configuration.AutoDetectChangesEnabled = false; } } return context; }</code>
Paramètres de réglage des performances clés:
batchSize
: Expérimentez les valeurs (par exemple, 100-1000) pour trouver la taille optimale du lot pour votre système. recycleContext
: Recycler le contexte améliore les performances en effacistant les entités suivies. Testez pour déterminer si cela offre un avantage dans votre scénario spécifique. SaveChanges()
Fréquence: Déterminez attentivement la fréquence idéale de SaveChanges()
appelle pour votre volume de données et votre configuration de base de données. En mettant en œuvre ces meilleures pratiques, vous pouvez considérablement améliorer les performances d'insertion du cadre d'entité et empêcher les délais d'emploi lorsque vous travaillez avec de grands ensembles de données.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!