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
Susan Sarandonoriginal
2025-01-11 14:03:41160parcourir

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>

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!

Déclaration:
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