- 实体框架教程
- 实体框架 - 首页
- 实体框架 - 概述
- 实体框架 - 架构
- 实体框架 - 环境设置
- 实体框架 - 数据库设置
- 实体框架 - 数据模型
- 实体框架 - DbContext
- 实体框架 - 类型
- 实体框架 - 关系
- 实体框架 - 生命周期
- 实体框架 - 代码优先方法
- 实体框架 - 模型优先方法
- 实体框架 - 数据库优先方法
- 实体框架 - 开发方法
- 实体框架 - 数据库操作
- 实体框架 - 并发
- 实体框架 - 事务
- 实体框架 - 视图
- 实体框架 - 索引
- 实体框架 - 存储过程
- 实体框架 - 断开连接的实体
- 实体框架 - 表值函数
- 实体框架 - 本机SQL
- 实体框架 - 枚举支持
- 实体框架 - 异步查询
- 实体框架 - 持久化
- 实体框架 - 投影查询
- 实体框架 - 命令日志
- 实体框架 - 命令拦截
- 实体框架 - 空间数据类型
- 实体框架 - 继承
- 实体框架 - 迁移
- 实体框架 - 渴望加载
- 实体框架 - 延迟加载
- 实体框架 - 显式加载
- 实体框架 - 验证
- 实体框架 - 跟踪更改
- 实体框架 - 彩色实体
- 实体框架 - 代码优先方法
- 实体框架 - 第一个示例
- 实体框架 - 数据注释
- 实体框架 - Fluent API
- 实体框架 - 播种数据库
- 实体框架 - 代码优先迁移
- 实体框架 - 多个DbContext
- 实体框架 - 嵌套实体类型
- 实体框架资源
- 实体框架 - 快速指南
- 实体框架 - 有用资源
- 实体框架 - 讨论
实体框架 - 数据库优先方法
在本章中,让我们学习如何使用数据库优先方法创建实体数据模型。
数据库优先方法为实体数据模型提供了代码优先和模型优先方法的替代方案。它从项目中的数据库创建模型代码(类、属性、DbContext 等),这些类成为数据库和控制器之间的链接。
数据库优先方法从现有的数据库创建实体框架。我们以与在模型优先方法中使用相同的方式使用所有其他功能,例如模型/数据库同步和代码生成。
让我们举一个简单的例子。我们已经有了一个数据库,其中包含 3 个表,如下面的图像所示。
步骤 1 - 让我们创建一个名为 DatabaseFirstDemo 的新控制台项目。
步骤 2 - 要创建模型,首先右键单击解决方案资源管理器中的控制台项目,然后选择添加→新项…
步骤 3 - 从中间窗格中选择 ADO.NET 实体数据模型,并在“名称”字段中输入 DatabaseFirstModel。
步骤 4 - 单击“添加”按钮,将启动实体数据模型向导对话框。
步骤 5 - 选择“从数据库 EF 设计器”,然后单击“下一步”按钮。
步骤 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...
执行上述程序时,您将看到之前在数据库中输入的所有学生的姓名。
我们建议您逐步执行以上示例以更好地理解。
广告