Lutte contre les délais d'attente du cadre d'entité
Les délais d'attente d'Entity Framework (EF) sont un problème fréquent lorsqu'il s'agit d'opérations de base de données longues, en particulier avec des ensembles de données importants. Voici comment résoudre ces problèmes :
1. Éliminer le délai d'attente de commande par défaut de la chaîne de connexion
EF ignore le paramètre Default Command Timeout
dans votre chaîne de connexion. Le supprimer évite les conflits potentiels.
2. Configurer CommandTimeout sur l'objet contextuel
Définissez directement la propriété CommandTimeout
sur votre objet de contexte de données dans votre référentiel. Cela garantit qu'EF respecte la valeur de délai d'attente spécifiée.
3. Ajustez votre version EF
La méthode de paramétrage CommandTimeout
dépend de votre version EF :
Entity Framework Core 1.0 et versions ultérieures :
<code class="language-csharp"> this.context.Database.SetCommandTimeout(180);</code>
Cadre d'entité 6 :
<code class="language-csharp"> this.context.Database.CommandTimeout = 180;</code>
Cadre d'entité 5 :
<code class="language-csharp"> ((IObjectContextAdapter)this.context).ObjectContext.CommandTimeout = 180;</code>
Entity Framework 4 et versions antérieures :
<code class="language-csharp"> this.context.CommandTimeout = 180;</code>
Important : Évitez de définir CommandTimeout
à la fois dans la chaîne de connexion et dans l'objet contextuel. Choisissez une méthode pour éviter les conflits.
En mettant en œuvre ces étapes, vous pouvez résoudre efficacement les problèmes de délai d'attente EF sans affecter négativement les performances sur des ensembles de données plus petits.
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!