实体框架 - 数据库优先方法

在本章中,让我们学习如何使用数据库优先方法创建实体数据模型。

  • 数据库优先方法为实体数据模型提供了一种替代代码优先和模型优先方法的方法。它从项目中的数据库创建模型代码(类、属性、DbContext 等),这些类成为数据库和控制器之间的链接。

  • 数据库优先方法从现有数据库创建实体框架。我们使用所有其他功能,例如模型/数据库同步和代码生成,就像我们在模型优先方法中使用它们一样。

我们举一个简单的例子。我们已经有一个包含 3 个表的数据库,如下图所示。

新控制台项目

步骤 1 − 让我们创建一个名称为 DatabaseFirstDemo 的新控制台项目。

步骤 2 − 要创​​建模型,首先在解决方案资源管理器中右键单击控制台项目,然后选择添加→ 新项目…

创建模型

步骤 3 − 从中间窗格中选择 ADO.NET 实体数据模型,然后在名称字段中输入名称 DatabaseFirstModel。

步骤 4 −单击"添加"按钮将启动"实体数据模型向导"对话框。

模型内容

步骤 5 − 从数据库中选择 EF 设计器并单击"下一步"按钮。

实体模型向导

步骤 6 − 选择现有数据库并单击"下一步"。

现有数据库

步骤 7 −选择 Entity Framework 6.x 并单击"下一步"。

Entity Framework

步骤 8 − 选择要包含的所有表视图和存储过程,然后单击"完成"。

您将看到从数据库生成了实体模型和 POCO 类。

POCO 类

现在让我们通过在 program.cs 文件中编写以下代码从数据库中检索所有学生。

using System;
using System.Linq;

namespace DatabaseFirstDemo {

   class Program {

      static void Main(string[] args) {

         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();
         }
      }
   }
}

执行上述程序时,您将收到以下输出 −

All student in the database:
Ali Khan
Arturo   finand
Bill Gates
Carson Alexander
Gytis Barzdukas
Laura Norman
Meredith Alonso
Nino Olivetto
Peggy Justice
Yan Li
Press any key to exit...

当执行上述程序时,您将看到之前在数据库中输入的所有学生的姓名。

为了更好地理解,我们建议您逐步执行上述示例。