乐趣区

Entity-Framework简介

零、什么是 Entity Framework

Entity Framework(简称 EF),是.NET 的 Object/Relational Mapping 实体框架(简称 ORM),可以在 SQL Server、MySQL、Oracle、等数据库上使用。可以将数据作为业务对象和实体进行操作,使用 LINQ 进行查询,使用 C# 进行操作和检索。

一、领域建模方式

Entity Framework 有三种领域建模方式:Code FirstModel FirstData First

  1. Code First

    Code First 可以通过类来描述模型,然后通过类来创建数据库,这种类简称为 POCO(Plain Old CLR Object)。POCO 中的 C 是指 .NET Framework 公共语言运行时(Common Language Runtime,CLR)中的一个简单对象。POCO 对域对象使用尽可能简单的类,可以包含属性、方法等,但是方法不能实现持久化逻辑,也就是说 POCO 也可以包含业务逻辑。Code First 优点如下:

    • 可以创建一个更富有逻辑、更灵活的应用程序;
    • 因为没有自动生成难以修改的代码,所以我们可以对代码完全控制;
    • 只需要定义映射,其余一切交给 Entity Framework 来处理;
    • 可以用修改代码的方式来修改数据库;
    • 可以使用它来映射表结构到一个已存在的数据库。
  2. Model First

    Model First 允许我们使用实体设计器在空模型中创建模型实体,及其关系和继承层次结构,然后创建数据库。优缺点如下:

    • 无法控制实体和数据库,因为自动生成的代码难以修改,但是对于小型且简单的项目,它仍行之有效;
    • 在实体中添加额外的功能,不得不修改 T4 模板或者使用部分类来完成;
    • 数据库模型的更改不是最佳选择,因为是由模型定义了数据库。
  3. Data First

    Data First 使我们能够从现有数据库创建模型,减少了自动生成代码所需编写的代码量,也限制了我们使用生成代码的结构。优缺点如下:

    • 如果已有 DBA 设计的数据来单独开发或已存在数据库,将作为首选
    • 通过 EDM 向导为我们创建实体、关系和继承层次结构,修改映射后还可以生成实体;
    • 要在实体中添加额外的功能,必须通过 T4 修改模板或者使用部分类;
    • 数据库的手动更改变为可能,如果要修改数据库表结构,只需要从数据库更新实体模型即可。
退出移动版