Maison > développement back-end > C++ > Comment implémenter d'abord la suppression en cascade pour les relations un à zéro ou un dans le code Entity Framework ?

Comment implémenter d'abord la suppression en cascade pour les relations un à zéro ou un dans le code Entity Framework ?

Susan Sarandon
Libérer: 2025-01-11 14:03:41
original
113 Les gens l'ont consulté

How to Implement Cascade Delete for One-to-Zero-or-One Relationships in Entity Framework Code First?

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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal