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