零、什么是Entity Framework
Entity Framework (简称EF),是.NET的 Object/Relational Mapping 实体框架(简称ORM),可以在 SQL Server、MySQL、Oracle、等数据库上使用。可以将数据作为业务对象和实体进行操作,使用LINQ进行查询,使用C#进行操作和检索。
一、领域建模方式
Entity Framework 有三种领域建模方式:Code First、Model First和Data First
-
Code First
Code First 可以通过类来描述模型,然后通过类来创建数据库,这种类简称为POCO(Plain Old CLR Object)。POCO中的C是指 .NET Framework公共语言运行时(Common Language Runtime,CLR)中的一个简单对象。POCO对域对象使用尽可能简单的类,可以包含属性、方法等,但是方法不能实现持久化逻辑,也就是说POCO也可以包含业务逻辑。Code First 优点如下:
- 可以创建一个更富有逻辑、更灵活的应用程序;
- 因为没有自动生成难以修改的代码,所以我们可以对代码完全控制;
- 只需要定义映射,其余一切交给Entity Framework来处理;
- 可以用修改代码的方式来修改数据库;
- 可以使用它来映射表结构到一个已存在的数据库。
-
Model First
Model First 允许我们使用实体设计器在空模型中创建模型实体,及其关系和继承层次结构,然后创建数据库。优缺点如下:
- 无法控制实体和数据库,因为自动生成的代码难以修改,但是对于小型且简单的项目,它仍行之有效;
- 在实体中添加额外的功能,不得不修改T4模板或者使用部分类来完成;
- 数据库模型的更改不是最佳选择,因为是由模型定义了数据库。
-
Data First
Data First 使我们能够从现有数据库创建模型,减少了自动生成代码所需编写的代码量,也限制了我们使用生成代码的结构。优缺点如下:
- 如果已有DBA设计的数据来单独开发或已存在数据库,将作为首选
- 通过EDM向导为我们创建实体、关系和继承层次结构,修改映射后还可以生成实体;
- 要在实体中添加额外的功能,必须通过T4修改模板或者使用部分类;
- 数据库的手动更改变为可能,如果要修改数据库表结构,只需要从数据库更新实体模型即可。