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!