Entity Framework - Opérations de base de données
Dans les chapitres précédents, vous avez appris trois manières différentes de définir un modèle de données d'entité.
Deux d'entre eux, Database First et Model First, dépendaient du concepteur Entity Framework combiné à la génération de code.
Le troisième, Code First, vous permet de sauter un concepteur visuel et d'écrire simplement votre propre code.
Quel que soit le chemin que vous choisissez, vous vous retrouverez avec des classes de domaine et une ou plusieurs classes Entity Framework DbContext vous permettent de récupérer et de conserver les données pertinentes pour ces classes.
L'API DbContext dans vos applications est utilisée comme un pont entre vos classes et votre base de données. Le DbContext est l'une des classes les plus importantes de Entity Framework.
Il permet d'exprimer et d'exécuter des requêtes.
Il prend les résultats de la requête de la base de données et les transforme en instances de nos classes de modèle.
Il peut suivre les modifications des entités, y compris l'ajout et la suppression, puis déclencher la création d'instructions d'insertion, de mise à jour et de suppression qui sont envoyées à la base de données à la demande.
Vous trouverez ci-dessous les classes de contexte d'annonces de domaine sur lesquelles nous allons effectuer différentes opérations dans ce chapitre. C'est le même exemple que nous avons créé dans le chapitre, Database First Approach.
Implémentation de classe de contexte
using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Data.Entity.Core.Objects;
using System.Linq;
namespace DatabaseFirstDemo {
public partial class UniContextEntities : DbContext {
public UniContextEntities(): base("name = UniContextEntities") {}
protected override void OnModelCreating(DbModelBuilder modelBuilder) {
throw new UnintentionalCodeFirstException();
}
public virtual DbSet<Course> Courses { get; set; }
public virtual DbSet<Enrollment> Enrollments { get; set; }
public virtual DbSet<Student> Students { get; set; }
}
}
Implémentation des classes de domaine
Classe de cours
namespace DatabaseFirstDemo {
using System;
using System.Collections.Generic;
public partial class Course {
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2214:DoNotCallOverridableMethodsInConstructors")]
public Course() {
this.Enrollments = new HashSet<Enrollment>();
}
public int CourseID { get; set; }
public string Title { get; set; }
public int Credits { get; set; }
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2227:CollectionPropertiesShouldBeReadOnly")]
public virtual ICollection<Enrollment> Enrollments { get; set; }
}
}
Classe étudiante
namespace DatabaseFirstDemo {
using System;
using System.Collections.Generic;
public partial class Student {
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2214:DoNotCallOverridableMethodsInConstructors")]
public Student() {
this.Enrollments = new HashSet<Enrollment>();
}
public int ID { get; set; }
public string LastName { get; set; }
public string FirstMidName { get; set; }
public System.DateTime EnrollmentDate { get; set; }
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2227:CollectionPropertiesShouldBeReadOnly")]
public virtual ICollection<Enrollment> Enrollments { get; set; }
}
}
Classe d'inscription
namespace DatabaseFirstDemo {
using System;
using System.Collections.Generic;
public partial class Enrollment {
public int EnrollmentID { get; set; }
public int CourseID { get; set; }
public int StudentID { get; set; }
public Nullable<int> Grade { get; set; }
public virtual Course Course { get; set; }
public virtual Student Student { get; set; }
}
}
Créer une opération
L'ajout d'un nouvel objet avec Entity Framework est aussi simple que la construction d'une nouvelle instance de votre objet et son enregistrement à l'aide de la méthode Add sur DbSet. Le code suivant vous permet d'ajouter un nouvel étudiant à la base de données.
class Program {
static void Main(string[] args) {
var newStudent = new Student();
//set student name
newStudent.FirstMidName = "Bill";
newStudent.LastName = "Gates";
newStudent.EnrollmentDate = DateTime.Parse("2015-10-21");
newStudent.ID = 100;
//create DBContext object
using (var dbCtx = new UniContextEntities()) {
//Add Student object into Students DBset
dbCtx.Students.Add(newStudent);
// call SaveChanges method to save student into database
dbCtx.SaveChanges();
}
}
}
Opération de mise à jour
La modification des objets existants est aussi simple que la mise à jour de la valeur attribuée aux propriétés que vous souhaitez modifier et l'appel de SaveChanges. Par exemple, le code suivant est utilisé pour changer le nom de famille d'Ali de Khan à Aslam.
using (var context = new UniContextEntities()) {
var student = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
student.LastName = "Aslam";
context.SaveChanges();
}
Supprimer l'opération
Pour supprimer une entité à l'aide d'Entity Framework, vous utilisez la méthode Remove sur DbSet. Supprimez les œuvres des entités existantes et nouvellement ajoutées. L'appel de Remove sur une entité qui a été ajoutée mais pas encore enregistrée dans la base de données annulera l'ajout de l'entité. L'entité est supprimée du suivi des modifications et n'est plus suivie par le DbContext. L'appel de Remove sur une entité existante qui fait l'objet d'un suivi des modifications enregistrera l'entité pour suppression la prochaine fois que SaveChanges sera appelé. L'exemple suivant est un code dans lequel l'étudiant est supprimé de la base de données dont le prénom est Ali.
using (var context = new UniContextEntities()) {
var bay = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
context.Students.Remove(bay);
context.SaveChanges();
}
Lire l'opération
La lecture des données existantes de la base de données est très simple. Voici le code dans lequel toutes les données de la table des étudiants sont récupérées, puis un programme sera affiché avec le prénom et le nom des étudiants dans l'ordre alphabétique.
using (var db = new UniContextEntities()) {
var query = from b in db.Students orderby b.FirstMidName select b;
Console.WriteLine("All All student in the database:");
foreach (var item in query) {
Console.WriteLine(item.FirstMidName +" "+ item.LastName);
}
Console.WriteLine("Press any key to exit...");
Console.ReadKey();
}