实体框架 – 数据库优先方法
实体框架 – 数据库优先方法
在本章中,让我们学习如何使用数据库优先方法创建实体数据模型。
-
数据库优先方法为实体数据模型的代码优先和模型优先方法提供了替代方法。它从项目中的数据库创建模型代码(类、属性、DbContext 等),这些类成为数据库和控制器之间的链接。
-
数据库优先方法从现有数据库创建实体框架。我们使用所有其他功能,例如模型/数据库同步和代码生成,与我们在模型优先方法中使用它们的方式相同。
我们举一个简单的例子。我们已经有一个包含 3 个表的数据库,如下图所示。
第 1 步– 让我们使用 DatabaseFirstDemo 名称创建一个新的控制台项目。
第 2 步– 要创建模型,首先在解决方案资源管理器中右键单击您的控制台项目,然后选择添加 → 新项目…
步骤 3 – 从中间窗格中选择 ADO.NET 实体数据模型,然后在名称字段中输入名称 DatabaseFirstModel。
步骤 4 – 单击添加按钮,这将启动实体数据模型向导对话框。
步骤 5 – 从数据库中选择 EF Designer,然后单击下一步按钮。
步骤 6 – 选择现有数据库并单击下一步。
步骤 7 – 选择实体框架 6.x,然后单击下一步。
步骤 8 – 选择要包含的所有表视图和存储过程,然后单击完成。
您将看到 Entity 模型和 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...
执行上述程序后,您将看到之前在数据库中输入的所有学生姓名。
我们建议您逐步执行上述示例,以便更好地理解。