实体框架 – DbContext

实体框架 – DbContext


实体框架使您能够使用称为实体的公共语言运行时 (CLR) 对象查询、插入、更新和删除数据。实体框架将模型中定义的实体和关系映射到数据库。它还提供设施 –

  • 将从数据库返回的数据具体化为实体对象
  • 跟踪对对象所做的更改
  • 处理并发
  • 将对象更改传播回数据库
  • 将对象绑定到控件

负责将数据作为对象进行交互的主要类是 System.Data.Entity.DbContext。DbContext API 不作为 .NET Framework 的一部分发布。为了更加灵活和频繁地向 Code First 和 DbContext API 发布新功能,实体框架团队通过 Microsoft 的 NuGet 分发功能分发了 EntityFramework.dll。

  • NuGet 允许您通过将相关 DLL 从 Web 直接拉入您的项目来添加对 .NET 项目的引用。

  • 称为库包管理器的 Visual Studio 扩展提供了一种将适当的程序集从 Web 提取到您的项目中的简单方法。

数据库上下文

  • DbContext API 主要旨在简化您与实体框架的交互。

  • 它还减少了访问常用任务所需的方法和属性的数量。

  • 在以前版本的实体框架中,发现和编码这些任务通常很复杂。

  • 上下文类在运行时管理实体对象,包括使用来自数据库的数据填充对象、更改跟踪以及将数据持久化到数据库。

定义 DbContext 派生类

推荐的使用上下文的方法是定义一个派生自 DbContext 的类,并公开表示上下文中指定实体集合的 DbSet 属性。如果您正在使用 EF 设计器,则会为您生成上下文。如果您使用 Code First,您通常会自己编写上下文。

下面的代码是一个简单的例子,它表明 UniContext 是从 DbContext 派生的。

  • 您可以将自动属性与 DbSet 一起使用,例如 getter 和 setter。

  • 它还使代码更简洁,但是当您没有其他逻辑可应用时,您无需将其用于创建 DbSet。

public class UniContext : DbContext {
   public UniContext() : base("UniContext") { }
   public DbSet<Student> Students { get; set; }
   public DbSet<Enrollment> Enrollments { get; set; }
   public DbSet<Course> Courses { get; set; }
}
  • 以前,EDM 用于生成从 ObjectContext 类派生的上下文类。

  • 使用 ObjectContext 有点复杂。

  • DbContext 是 ObjectContext 的包装器,它实际上类似于 ObjectContext,并且在所有开发模型(例如 Code First、Model First 和 Database First)中都很有用且简单。

查询

您可以使用三种类型的查询,例如 –

  • 添加新实体。
  • 更改或更新现有实体的属性值。
  • 删除现有实体。

添加新实体

使用实体框架添加新对象就像构造对象的新实例并使用 DbSet 上的 Add 方法注册它一样简单。以下代码适用于要向数据库添加新学生的情况。

private static void AddStudent() {

   using (var context = new UniContext()) {

      var student = new Student {
         LastName = "Khan", 
         FirstMidName = "Ali", 
         EnrollmentDate = DateTime.Parse("2005-09-01") 
      };

      context.Students.Add(student); 
      context.SaveChanges();

   }
}

更改现有实体

更改现有对象就像更新分配给要更改的属性的值并调用 SaveChanges 一样简单。在下面的代码中,Ali 的姓氏从 Khan 改为 Aslam。

private static void AddStudent() {

   private static void ChangeStudent() {

      using (var context = new UniContext()) {

         var student = (from d in context.Students
            where d.FirstMidName == "Ali" select d).Single();
         student.LastName = "Aslam";
         context.SaveChanges();

      }
   }
}

删除现有实体

要使用实体框架删除实体,请使用 DbSet 上的 Remove 方法。删除适用于现有和新添加的实体。对已添加但尚未保存到数据库的实体调用 Remove 将取消该实体的添加。该实体从更改跟踪器中删除,不再由 DbContext 跟踪。对正在被更改跟踪的现有实体调用 Remove 将注册该实体以在下次调用 SaveChanges 时删除。以下示例显示了从数据库中删除名字为 Ali 的学生的实例。

private static void DeleteStudent() {

   using (var context = new UniContext()) {
      var bay = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
      context.Students.Remove(bay);
      context.SaveChanges();
   }
}

觉得文章有用?

点个广告表达一下你的爱意吧 !😁