Entity Framework - Model First Approach

Dans ce chapitre, apprenons à créer un modèle de données d'entité dans le concepteur à l'aide du flux de travail appelé Model First.

  • Model First est idéal lorsque vous démarrez un nouveau projet où la base de données n'existe même pas encore.

  • Le modèle est stocké dans un fichier EDMX et peut être affiché et modifié dans Entity Framework Designer.

  • Dans Model First, vous définissez votre modèle dans un concepteur Entity Framework, puis générez du SQL, qui créera un schéma de base de données correspondant à votre modèle, puis vous exécuterez le SQL pour créer le schéma dans votre base de données.

  • Les classes avec lesquelles vous interagissez dans votre application sont automatiquement générées à partir du fichier EDMX.

Voici un exemple simple de création d'un nouveau projet de console à l'aide de l'approche Model First.

Step 1 - Ouvrez Visual Studio et sélectionnez Fichier → Nouveau → Projet

Step 2 - Sélectionnez Installé → Modèles → Visual C # → Windows dans le volet gauche, puis dans le volet central, sélectionnez Application console.

Step 3 - Entrez EFModelFirstDemo dans le champ Nom.

Step 4 - Pour créer un modèle, faites d'abord un clic droit sur votre projet de console dans l'explorateur de solutions et sélectionnez Ajouter → Nouveaux éléments…

La boîte de dialogue suivante s'ouvre.

Step 5 - Sélectionnez ADO.NET Entity Data Model dans le volet central et entrez le nom ModelFirstDemoDB dans le champ Nom.

Step 6 - Cliquez sur le bouton Ajouter qui lancera la boîte de dialogue Assistant de modèle de données d'entité.

Step 7- Sélectionnez le modèle Empty EF Designer et cliquez sur le bouton Suivant. Le concepteur Entity Framework s'ouvre avec un modèle vide. Nous pouvons maintenant commencer à ajouter des entités, des propriétés et des associations au modèle.

Step 8- Cliquez avec le bouton droit sur l'aire de conception et sélectionnez Propriétés. Dans la fenêtre Propriétés, modifiez le nom du conteneur d'entité en ModelFirstDemoDBContext.

Step 9 - Cliquez avec le bouton droit de la souris sur l'aire de conception et sélectionnez Ajouter nouveau → Entité…

La boîte de dialogue Ajouter une entité s'ouvre, comme illustré dans l'image suivante.

Step 10 - Entrez Student comme nom d'entité et Student Id comme nom de propriété et cliquez sur OK.

Step 11 - Cliquez avec le bouton droit sur la nouvelle entité sur l'aire de conception et sélectionnez Ajouter nouveau → Propriété scalaire, entrez Nom comme nom de la propriété.

Step 12 - Entrez FirstName, puis ajoutez deux autres propriétés scalaires telles que LastName et EnrollmentDate.

Step 13 - Ajoutez deux autres cours d'entités et inscription en suivant toutes les étapes mentionnées ci-dessus et ajoutez également des propriétés scalaires comme indiqué dans les étapes suivantes.

Step 14 - Nous avons trois entités dans Visual Designer, ajoutons une association ou une relation entre elles.

Step 15 - Cliquez avec le bouton droit de la souris sur l'aire de conception et sélectionnez Ajouter nouveau → Association…

Step 16 - Faites une extrémité de la relation pointer vers l'étudiant avec une multiplicité de l'un et l'autre extrémité vers l'inscription avec une multiplicité de plusieurs.

Step 17 - Cela signifie qu'un étudiant a de nombreuses inscriptions et que l'inscription appartient à un seul étudiant.

Step 18 - Assurez-vous que la case Ajouter les propriétés de la clé étrangère à l'entité «Post» est cochée et cliquez sur OK.

Step 19 - De même, ajoutez une autre association entre le cours et l'inscription.

Step 20 - Votre modèle de données ressemblera à l'écran suivant après l'ajout d'associations entre les entités.

Nous avons maintenant un modèle simple à partir duquel nous pouvons générer une base de données et l'utiliser pour lire et écrire des données. Allons-y et générons la base de données.

Step 1 - Cliquez avec le bouton droit de la souris sur l'aire de conception et sélectionnez Générer la base de données à partir du modèle…

Step 2 - Vous pouvez sélectionner une base de données existante ou créer une nouvelle connexion en cliquant sur Nouvelle connexion…

Step 3 - Pour créer une nouvelle base de données, cliquez sur Nouvelle connexion…

Step 4 - Entrez le nom du serveur et le nom de la base de données.

Step 5 - Cliquez sur Suivant.

Step 6- Cliquez sur Terminer. Cela ajoutera le fichier * .edmx.sql dans le projet. Vous pouvez exécuter des scripts DDL dans Visual Studio en ouvrant le fichier .sql, puis cliquez avec le bouton droit et sélectionnez Exécuter.

Step 7 - La boîte de dialogue suivante s'affiche pour vous connecter à la base de données.

Step 8 - En cas d'exécution réussie, vous verrez le message suivant.

Step 9 - Allez dans l'explorateur de serveur, vous verrez que la base de données est créée avec trois tables qui sont spécifiées.

Ensuite, nous devons permuter notre modèle pour générer du code qui utilise l'API DbContext.

Step 1 - Cliquez avec le bouton droit de la souris sur un emplacement vide de votre modèle dans EF Designer et sélectionnez Ajouter un élément de génération de code…

Vous verrez que la boîte de dialogue Ajouter un nouvel élément suivante s'ouvre.

Step 2 - Sélectionnez EF 6.x DbContext Generator dans le volet central et entrez ModelFirstDemoModel dans le champ Nom.

Step 3 - Vous verrez dans votre explorateur de solutions que les modèles ModelFirstDemoModel.Context.tt et ModelFirstDemoModel.tt sont générés.

Le ModelFirstDemoModel.Context génère le DbCcontext et les ensembles d'objets que vous pouvez retourner et utiliser pour interroger, par exemple pour le contexte, les étudiants et les cours, etc.

L'autre modèle traite de tous les types Étudiant, Cours, etc. Voici la classe Étudiant, qui est générée automatiquement à partir du modèle d'entité.

Voici le code C # dans lequel certaines données sont entrées et extraites de la base de données.

using System;
using System.Linq;

namespace EFModelFirstDemo {

   class Program {

      static void Main(string[] args) {

         using (var db = new ModelFirstDemoDBContext()) {

            // Create and save a new Student

            Console.Write("Enter a name for a new Student: ");
            var firstName = Console.ReadLine();

            var student = new Student {
               StudentID = 1,
               FirstName = firstName
            };
				
            db.Students.Add(student);
            db.SaveChanges();
				
            var query = from b in db.Students
               orderby b.FirstName select b;

            Console.WriteLine("All student in the database:");

            foreach (var item in query) {
               Console.WriteLine(item.FirstName);
            }

            Console.WriteLine("Press any key to exit...");
            Console.ReadKey();
         }
      }
   }
}

Lorsque le code ci-dessus est exécuté, vous recevrez la sortie suivante -

Enter a name for a new Student:
Ali Khan
All student in the database:
Ali Khan
Press any key to exit...

Nous vous recommandons d'exécuter l'exemple ci-dessus étape par étape pour une meilleure compréhension.