Entity Framework Code First : suppressions en cascade dans des relations un à zéro ou un
Dans Entity Framework Code First, la gestion des relations un à zéro ou un nécessite un examen attentif des suppressions en cascade. Cela garantit que les entités dépendantes sont automatiquement supprimées lorsque leur entité parent associée est supprimée.
Illustrons avec un scénario « Utilisateur » et « UserDetail ». Un « utilisateur » peut ou non avoir un enregistrement « UserDetail ». Sans configuration appropriée, la suppression d'un « Utilisateur » laisse l'enregistrement « UserDetail » associé orphelin.
La solution réside dans l'utilisation de l'API fluide au sein de la méthode OnModelCreating
de votre classe DbContext :
<code class="language-csharp">protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Entity<User>() .HasOptional(a => a.UserDetail) .WithOptionalDependent() .WillCascadeOnDelete(true); }</code>
Cet extrait de code établit la relation un à zéro ou un en utilisant HasOptional
et WithOptionalDependent
. Surtout, WillCascadeOnDelete(true)
active les suppressions en cascade. Désormais, la suppression d'un « Utilisateur » supprimera automatiquement l'entrée « UserDetail » correspondante, préservant ainsi l'intégrité des données. Cela simplifie la méthode Delete
dans votre UserRepository
, garantissant que les deux enregistrements sont supprimés en une seule opération.
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!