Maison >développement back-end >C++ >Comment empêcher Entity Framework de générer automatiquement des clés primaires ?

Comment empêcher Entity Framework de générer automatiquement des clés primaires ?

Barbara Streisand
Barbara Streisandoriginal
2025-01-14 09:56:43441parcourir

How to Prevent Entity Framework from Automatically Generating Primary Keys?

Suppression de la génération automatique de clé primaire dans Entity Framework

L'approche code first d'Entity Framework génère souvent automatiquement des clés primaires, en particulier des colonnes d'identité à incrémentation automatique. Ce comportement automatique n'est pas toujours adapté. Cet article explique comment remplacer cette fonctionnalité par défaut.

Une approche courante utilise une configuration API fluide :

<code class="language-csharp">modelBuilder.Entity<Event>().Property(e => e.EventID).HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);</code>

Cependant, cela peut conduire à l'erreur : "Impossible d'insérer une valeur explicite pour la colonne d'identité dans la table 'Événements' lorsque IDENTITY_INSERT est défini sur OFF."

Comprendre l'erreur

Cette erreur résulte d'un conflit. DatabaseGeneratedOption.None empêche EF de générer des identifiants, mais la table de base de données possède toujours la propriété IDENTITY, créant un conflit lors de la tentative d'attribution manuelle de valeurs de clé.

Résolution

La solution consiste à désactiver la propriété IDENTITY sur la colonne ID de la base de données. Utilisez cette commande SQL :

<code class="language-sql">ALTER TABLE Events ALTER COLUMN EventID INT NOT NULL</code>

Alternative basée sur les attributs

Vous pouvez également utiliser des attributs directement dans votre classe d'entité :

<code class="language-csharp">[Key]
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int EventID { get; set; }</code>

Cette méthode fonctionne également correctement avec EF Core.

En implémentant ces solutions, les développeurs prennent le contrôle de l'attribution des clés primaires, en spécifiant manuellement les valeurs et en contournant la génération automatique par défaut d'EF.

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