Entity Framework 6 a ajouté la prise en charge de plusieurs DbContext
s en ajoutant les indicateurs -ContextTypeName
et -MigrationsDirectory
. J'ai juste exécuté les commandes dans ma console du gestionnaire de package et collé la sortie ci-dessous ...
Si vous avez 2 DbContext
s dans votre projet et que vous exécutez enable-migrations
, vous obtiendrez une erreur (comme vous le savez probablement déjà):
PM> enable-migrations
More than one context type was found in the assembly 'WebApplication3'.
To enable migrations for 'WebApplication3.Models.ApplicationDbContext', use Enable-Migrations -ContextTypeName WebApplication3.Models.ApplicationDbContext.
To enable migrations for 'WebApplication3.Models.AnotherDbContext', use Enable-Migrations -ContextTypeName WebApplication3.Models.AnotherDbContext.
Vous devez donc exécuter enable-migrations
chacun DbContext
séparément. Et vous devez spécifier un dossier pour chaque Configuration.cs
fichier à générer ...
PM> Enable-Migrations -ContextTypeName ApplicationDbContext -MigrationsDirectory Migrations\ApplicationDbContext
Checking if the context targets an existing database...
Code First Migrations enabled for project WebApplication3.
PM> Enable-Migrations -ContextTypeName AnotherDbContext -MigrationsDirectory Migrations\AnotherDbContext
Checking if the context targets an existing database...
Code First Migrations enabled for project WebApplication3.
Pour ajouter des migrations pour chacun DbContext
, procédez comme suit en spécifiant le nom complet de la Configuration
classe:
PM> Add-Migration -ConfigurationTypeName WebApplication3.Migrations.ApplicationDbContext.Configuration "InitialDatabaseCreation"
Scaffolding migration 'InitialDatabaseCreation'.
The Designer Code for this migration file includes a snapshot of your current Code First model. This snapshot is used to calculate the changes to your model when you scaffold the next migration. If you make additional changes to your model that you want to include in this migration, then you can re-scaffold it by running 'Add-Migration InitialDatabaseCreation' again.
PM> Add-Migration -ConfigurationTypeName WebApplication3.Migrations.AnotherDbContext.Configuration "InitialDatabaseCreation"
Scaffolding migration 'InitialDatabaseCreation'.
The Designer Code for this migration file includes a snapshot of your current Code First model. This snapshot is used to calculate the changes to your model when you scaffold the next migration. If you make additional changes to your model that you want to include in this migration, then you can re-scaffold it by running 'Add-Migration InitialDatabaseCreation' again.
Et vous exécutez de update-database
la même manière:
PM> Update-Database -ConfigurationTypeName WebApplication3.Migrations.ApplicationDbContext.Configuration
Specify the '-Verbose' flag to view the SQL statements being applied to the target database.
Applying explicit migrations: [201402032113124_InitialDatabaseCreation].
Applying explicit migration: 201402032113124_InitialDatabaseCreation.
Running Seed method.
PM> Update-Database -ConfigurationTypeName WebApplication3.Migrations.AnotherDbContext.Configuration
Specify the '-Verbose' flag to view the SQL statements being applied to the target database.
Applying explicit migrations: [201402032113383_InitialDatabaseCreation].
Applying explicit migration: 201402032113383_InitialDatabaseCreation.
Running Seed method.
J'espère que cela t'aides.
MigrateDatabaseToLatestVersion
forzing thectx.Database.initialize()
de chaque contexte pour exécuter dans le bon ordre, ou exécuter laUpdate-Database
commande à la main dans le bon ordre. (Et l'inverse, si vous effectuez une migration de base de données vers la version précédente). C'est "dangereux" mais peut être fait.