Exclusion du modèle de données EF en raison d'une clé primaire manquante
Lors de l'intégration d'une base de données existante dans Entity Framework (EF) 4.0, il est courant que certaines tables manquent de clés primaires. Ce problème se produit lors de la création d'un nouveau modèle de données d'entité, entraînant un message d'erreur indiquant que la clé primaire est manquante et que la table est ensuite exclue.
On pense généralement qu'une clé primaire physique doit être ajoutée à la table concernée pour résoudre ce problème. Il existe cependant une solution de contournement qui permet d'utiliser ces tables sans modifier leur schéma.
Comme l'a suggéré Tillito, cette solution de contournement implique de modifier l'instruction SELECT de la vue incriminée dans une nouvelle instruction SELECT. En encapsulant ainsi l'instruction SELECT d'origine, vous pouvez utiliser la fonction ISNULL pour spécifier la colonne à utiliser comme clé primaire. Au lieu de cela, vous pouvez utiliser la fonction NULLIF pour empêcher qu'une colonne soit désignée comme clé primaire.
Exemple :
Considérons l'exemple suivant :
<code class="language-sql">SELECT ISNULL(MyPrimaryID,-999) MyPrimaryID, NULLIF(AnotherProperty,'') AnotherProperty FROM ( ... ) AS temp</code>
Dans cet exemple, la fonction ISNULL force EF à reconnaître "MyPrimaryID" comme clé primaire, tandis que la fonction NULLIF garantit que "AnotherProperty" n'est pas considéré comme une clé primaire.
En appliquant cette technique, vous évitez d'avoir à modifier le schéma de la base de données et intégrez de manière transparente les tables existantes dans votre modèle de données EF, permettant la manipulation des données sans modifications des clés primaires physiques.
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!