📅  最后修改于: 2020-11-21 07:19:13             🧑  作者: Mango
在前面的章节中,您学习了定义实体数据模型的三种不同方式。
其中两个是Database First和Model First,它们依赖于Entity Framework设计器并结合了代码生成。
第三个是“代码优先”,它使您可以跳过视觉设计师,而只编写自己的代码。
无论选择哪种路径,最终都会得到域类,并且一个或多个Entity Framework DbContext类使您可以检索和持久化与这些类相关的数据。
应用程序中的DbContext API用作类和数据库之间的桥梁。 DbContext是实体框架中最重要的类之一。
它可以表达和执行查询。
它从数据库中获取查询结果,并将其转换为我们的模型类的实例。
它可以跟踪对实体的更改,包括添加和删除,然后触发创建插入,更新和删除语句,这些语句按需发送到数据库。
以下是我们将在本章中执行不同操作的域广告上下文类。这与我们在“数据库优先方法”一章中创建的示例相同。
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 Courses { get; set; }
public virtual DbSet Enrollments { get; set; }
public virtual DbSet Students { get; set; }
}
}
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();
}
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 Enrollments { get; set; }
}
}
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();
}
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 Enrollments { get; set; }
}
}
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 Grade { get; set; }
public virtual Course Course { get; set; }
public virtual Student Student { get; set; }
}
}
使用Entity Framework添加新对象就像构造对象的新实例并使用DbSet上的Add方法注册它一样简单。以下代码使您可以向数据库中添加新学生。
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();
}
}
}
更改现有对象就像更新分配给要更改的属性的值并调用SaveChanges一样简单。例如,以下代码用于将Ali的姓氏从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();
}
若要使用Entity Framework删除实体,请在DbSet上使用Remove方法。删除适用于现有实体和新添加的实体。对已添加但尚未保存到数据库的实体调用“删除”将取消该实体的添加。该实体已从更改跟踪器中删除,并且不再由DbContext跟踪。在要进行更改跟踪的现有实体上调用Remove将在下次调用SaveChanges时注册要删除的实体。以下示例是一个代码,其中该学生从名字为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();
}
从数据库读取现有数据非常简单。以下是检索学生表中所有数据的代码,然后将显示一个程序,其中按字母顺序显示学生的名字和姓氏。
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();
}