Portage d’un modèle EDMX EF6 vers EF CorePorting an EF6 EDMX-Based Model to EF Core

EF Core ne prend pas en charge le format de fichier EDMX pour les modèles.EF Core does not support the EDMX file format for models. La meilleure option pour ces modèles, le port doit générer un nouveau modèle basé sur le code à partir de la base de données pour votre application.The best option to port these models, is to generate a new code-based model from the database for your application.

Installer les packages NuGet de noyaux EFInstall EF Core NuGet packages

Installer le Microsoft.EntityFrameworkCore.Tools package NuGet.Install the Microsoft.EntityFrameworkCore.Tools NuGet package.

Régénérer le modèleRegenerate the model

Vous pouvez désormais utiliser les fonctionnalités de l’ingénierie à rebours pour créer un modèle basé sur votre base de données existante.You can now use the reverse engineer functionality to create a model based on your existing database.

Exécutez la commande suivante dans la Console du Gestionnaire de Package (Outils -> Gestionnaire de Package NuGet -> Console du Gestionnaire de Package).Run the following command in Package Manager Console (Tools –> NuGet Package Manager –> Package Manager Console). Consultez Package Manager Console (Visual Studio) pour structurer un sous-ensemble de tables, etc. des options de commande.See Package Manager Console (Visual Studio) for command options to scaffold a subset of tables etc.

Scaffold-DbContext "<connection string>" <database provider name>

Par exemple, voici la commande pour structurer un modèle à partir de la base de données de création de blogs sur votre instance de base de données SQL Server locale.For example, here is the command to scaffold a model from the Blogging database on your SQL Server LocalDB instance.

Scaffold-DbContext "Server=(localdb)\mssqllocaldb;Database=Blogging;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer

Supprimer le modèle de EF6Remove EF6 model

Vous pouvez maintenant supprimer le modèle de EF6 à partir de votre application.You would now remove the EF6 model from your application.

Il convient de laisser le package NuGet de EF6 (EntityFramework) est installé, comme EF Core et EF6 peuvent être utilisé côte à côte dans la même application.It is fine to leave the EF6 NuGet package (EntityFramework) installed, as EF Core and EF6 can be used side-by-side in the same application. Toutefois, si vous n’êtes pas l’intention d’utiliser des EF6 dans les zones de votre application, puis désinstaller le package vous permettent d’exercer des erreurs de compilation sur les segments de code nécessitant une attention particulière.However, if you aren't intending to use EF6 in any areas of your application, then uninstalling the package will help give compile errors on pieces of code that need attention.

Mettre à jour votre code.Update your code

À ce stade, il est une question d’adressage des erreurs de compilation et de révision de code pour voir si les modifications de comportement entre EF6 et EF Core auront un impact.At this point, it's a matter of addressing compilation errors and reviewing code to see if the behavior changes between EF6 and EF Core will impact you.

Le port de testTest the port

Le simple fait que votre application est compilé, ne signifie pas qu’il est correctement déplacée vers EF Core.Just because your application compiles, does not mean it is successfully ported to EF Core. Vous devez tester toutes les zones de votre application pour vous assurer qu’aucun des changements de comportement ont affectées votre application.You will need to test all areas of your application to ensure that none of the behavior changes have adversely impacted your application.

Conseil

Consultez mise en route avec EF de base sur ASP.NET Core avec une base de données pour une référence supplémentaire sur la façon de travailler avec une base de données existanteSee Getting Started with EF Core on ASP.NET Core with an Existing Database for an additional reference on how to work with an existing database,