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
Libérer: 2025-01-14 09:56:43
original
447 Les gens l'ont consulté

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

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

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

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!

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