Maison  >  Article  >  base de données  >  Pourquoi Entity Framework crée-t-il des tables singulières dans MySQL même lorsque mon modèle est pluriel ?

Pourquoi Entity Framework crée-t-il des tables singulières dans MySQL même lorsque mon modèle est pluriel ?

DDD
DDDoriginal
2024-10-31 08:03:30295parcourir

Why Does Entity Framework Create Singular Tables in MySQL Even When My Model is Plural?

Conflit de noms de table au pluriel dans Entity Framework

Ce problème survient lors de l'utilisation d'Entity Framework avec MySQL et de la tentative de création d'une table avec un nom au pluriel à partir d'un modèle singulier.

PROBLÈME :

Dans le code fourni, une table nommée "votes" est attendue par la vue, mais Entity Framework crée une table nommée " voter" dans MySQL. Cette divergence entraîne l'exception : "La table 'mydb.vote' n'existe pas."

SOLUTION :

Pour résoudre ce problème, les étapes suivantes peuvent être pris :

  1. Supprimer l'appel du constructeur de base dans OnModelCreating :
    À l'origine, l'appel du constructeur de base était utilisé dans OnModelCreating pour implémenter la pluralisation. Cependant, il est recommandé de supprimer cet appel pour empêcher le comportement de pluralisation.
  2. Supprimer la PluralizingTableNameConvention :
    Le code comprenait initialement une ligne pour supprimer la PluralizingTableNameConvention. Ceci est toujours nécessaire pour empêcher la pluralisation automatique des noms de table.
  3. Supprimez la base de données existante :
    Il est recommandé de supprimer la base de données existante, puis d'autoriser Entity Framework à créer une nouvelle un. Cela garantit que le nom de table correct est utilisé.
  4. Assurez-vous des autorisations de création de base de données :
    Vérifiez que l'utilisateur MySQL spécifié dans la chaîne de connexion dispose des autorisations suffisantes pour créer de nouvelles bases de données.
  5. Supprimer la pluralisation d'ApplicationStart :
    Le code utilisait à l'origine DropCreateDatabaseAlways, qui désactivait la pluralisation. Cependant, cela n'a pas été correctement implémenté en tant que Database.SetInitializer(new DropCreateDatabaseAlways()). Au lieu de cela, il devrait s'agir de Database.SetInitializer(new myDBInitializer()).

Après avoir implémenté ces modifications, Entity Framework devrait créer correctement la table « votes » dans MySQL, résolvant le conflit de nom de table et permettant le vue pour fonctionner correctement.

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