学懂C#编程:常用框架学习(三)——.NET Framework框架下的Entity Framework (EF)开发应用详解
创始人
2025-01-11 12:03:53
0

        

目录

一、Entity Framework概述

二、Entity Framework的核心组成部分

Entity Data Model (EDM):

Entity Client:

Object Services:

ADO.NET Provider:

三、分层结构

应用程序层:

Entity Framework层:

数据库层:

四、EF 主要的功能包括

五、三种开发模式详解

1. 代码优先(Code First)

2. 数据库优先(Database First)

3. 模型优先(Model First)

六、总结


Entity Framework (EF) 是一个开源的对象关系映射 (ORM) 框架,它可以使 .NET 开发者能够使用 LINQ 查询关系型数据库,并且可以在 .NET 对象和数据库间转换数据。EF 提供了一种高级的抽象,让开发者不需要直接编写 SQL 查询和处理数据转换

        EF支持三种主要的开发模式:代码优先(Code First)、数据库优先(Database First)和模型优先(Model First)。下面将结合实际案例,详细讲解这三种模式,帮助初学者轻松理解和掌握。

一、Entity Framework概述

Entity Framework通过提供一组丰富的API和工具,使得数据访问层的开发变得更加简单和高效。它支持多种数据库系统,如SQL Server、MySQL、Oracle等,并允许开发人员使用LINQ(Language Integrated Query)来查询和操作数据。

二、Entity Framework的核心组成部分

  1. Entity Data Model (EDM)

    • 概念层(CSDL, Conceptual Schema Definition Language):定义了应用程序中的实体和它们之间的关系,这些实体对应于数据库中的表或视图。CSDL是EDM的“灵魂”部分,它用实体类表示数据库中的对象。
    • 存储层(SSDL, Store Schema Definition Language):描述了数据库的实际结构,包括表、列、关系、主键及索引等。SSDL将数据库中的对象信息加载到EF中,并描述数据库对象的结构信息。
    • 映射层(MSL, Mapping Specification Language):负责将概念层(CSDL)与存储层(SSDL)进行映射,确保应用程序中的实体能够正确地映射到数据库中的表或视图。

    这些部分通常以XML格式定义,并存储在.edmx文件中,该文件是EF实现ORM的关键配置文件。

  2. Entity Client

    • Entity Client是EF提供的一套类似于ADO.NET的数据库操作类,它主要用于操作EDM。与ADO.NET直接向数据库发送SQL命令不同,Entity Client是向EDM发送Entity SQL(EF特有的SQL方言),然后由EF将其转换为数据库可理解的SQL语句。
  3. Object Services

    • Object Services提供了丰富的API,允许开发人员以面向对象的方式操作数据。这些API隐藏了底层数据库操作的复杂性,使得开发人员可以更加专注于业务逻辑的实现。
  4. ADO.NET Provider

    • ADO.NET Provider是EF与数据库之间的桥梁,它负责将Entity Client的操作命令翻译为数据库的SQL语句,并执行这些语句。Microsoft默认实现了对SQL Server的ADO.NET Provider,但也可以通过其他数据库厂商提供的插件来支持其他数据库。

三、分层结构

从逻辑上讲,EF框架的分层结构可以归纳为以下几个层次:

  1. 应用程序层

    • 开发人员在这一层编写业务逻辑代码,通过EF提供的API来操作数据。这些API以面向对象的方式封装了数据库操作,使得开发人员可以像操作普通对象一样操作数据库中的数据。
  2. Entity Framework层

    • 这一层是EF框架的核心,它包含了EDM、Entity Client、Object Services等关键组成部分。EF层负责将应用程序层的请求转换为数据库可理解的SQL语句,并将执行结果返回给应用程序层。
  3. 数据库层

    • 数据库层是实际存储数据的地方,它可以是任何支持ADO.NET的关系型数据库。ADO.NET Provider负责将EF层生成的SQL语句发送到数据库层执行,并将执行结果返回给EF层。

四、EF 主要的功能包括

  • 通过 LINQ 查询数据
  • 跟踪对象的状态变化并将这些变化持久化到数据库
  • 支持事务处理
  • 支持数据库迁移,即可以根据模型变化自动更新数据库结构。

五、三种开发模式详解

1. 代码优先(Code First)

核心思想:先编写实体类和数据上下文(DbContext),然后根据这些代码生成数据库。

适用场景:适用于新项目,或对数据库结构有完全控制权的情况。

实际案例

假设我们要开发一个简单的博客系统,包含作者(Author)和文章(Post)两个实体。

1)定义实体类

public class Author   {       public int AuthorId { get; set; }       public string Name { get; set; }   }    public class Post   {       public int PostId { get; set; }       public string Title { get; set; }       public string Content { get; set; }       public int AuthorId { get; set; }       public Author Author { get; set; }   }

2)定义数据上下文

public class BlogContext : DbContext   {       public DbSet Authors { get; set; }       public DbSet Posts { get; set; }        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)       {           optionsBuilder.UseSqlServer(@"Server=(localdb)\mssqllocaldb;Database=BlogDb;Trusted_Connection=True;");       }   }

3)使用迁移生成数据库

在Visual Studio中,通过Package Manager Console运行以下命令:

Enable-Migrations   Add-Migration InitialCreate   Update-Database

这些命令会生成数据库迁移文件,并根据迁移文件创建数据库。 

2. 数据库优先(Database First)

核心思想:从现有数据库生成实体类和映射文件,然后在此基础上进行开发。

适用场景:适用于已有数据库的情况,如维护现有系统或集成第三方数据库。

实际案例

假设我们有一个现成的数据库,包含Authors和Posts两个表。

3. 模型优先(Model First)

核心思想:先设计数据模型,然后根据模型生成数据库。

适用场景:适用于从零开始设计数据模型的情况,或需要高度定制数据库结构的情况。

实际案例

 1)在Visual Studio中设计模型

          通过添加“ADO.NET Entity Data Model”项,选择“空模型”,并使用设计器添加实体和关系。   2)生成数据库脚本

           设计完成后,右键点击模型图,选择“生成数据库脚本”,将生成的SQL脚本在数据库中执行,以创建数据库和表。

3)使用生成的实体类进行数据操作

     与Database First类似,Model First也生成了实体类,可以直接在代码中使用。

  1. 使用Entity Framework Power Tools或dotnet ef工具生成模型

    在Visual Studio中,可以通过添加“ADO.NET Entity Data Model”项,并选择“从数据库生成模型”来生成实体类和映射文件。或者使用dotnet ef工具:

    dotnet ef dbcontext scaffold "Server=(localdb)\mssqllocaldb;Database=ExistingDb;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -o Models

  2. 这将根据数据库中的表生成相应的实体类和DbContext。

  3. 使用生成的实体类进行数据操作

    生成的实体类可以直接在代码中使用,进行CRUD操作。

六、总结

Entity Framework的三种开发模式各有优缺点和适用场景。Code First模式提供了最大的灵活性,适合新项目或对数据库结构有完全控制权的情况;Database First模式适用于已有数据库的情况,可以快速生成实体类和映射文件;Model First模式则适用于从零开始设计数据模型的情况。根据项目的具体需求选择合适的开发模式

相关内容

热门资讯

透视辅助!AApOKER软件透... 透视辅助!AApOKER软件透明挂,aapoker后台好像是有挂(详细透明挂教程);进入游戏-大厅左...
红龙扑克辅助!红龙扑克都是机器... 红龙扑克辅助!红龙扑克都是机器人吗(红龙扑克)真是有挂(详细辅助器教程)1、不需要AI权限,帮助你快...
黑科技透明挂!德州wepowe... 黑科技透明挂!德州wepower好像真的有挂,Wepoke透明挂总是存在有挂(详细黑科技教程)1、每...
wepoke透视挂!cloud... wepoke透视挂!cloudpoker本来真的有挂,wpk脚本(详细脚本辅助器安装教程)1、wep...
德扑之星开桌(德扑之星有辅)辅... 德扑之星开桌(德扑之星有辅)辅助工具(辅助挂)竟然有挂(详细手牌教程);辅助插件是一个在免局卡环境下...
六分钟了解!德扑之星辅助工具,... 六分钟了解!德扑之星辅助工具,德扑之星有辅真是是真的有挂(详细有作弊教程)1、系统规律教程、辅助透视...
黑科技辅助!wEpoke总是存... 黑科技辅助!wEpoke总是存在有挂,Wepoke后台本来真的是有挂(详细ai代打的胜率教程)1、点...
红龙扑克辅助!哈糖大菠萝一贯有... 红龙扑克辅助!哈糖大菠萝一贯有挂,wepoke有挂 网上(详细透明挂辅助器教程),您好,红龙扑克辅助...
8分钟了解!微扑克辅助器,微扑... 8分钟了解!微扑克辅助器,微扑克规律竟然有挂(详细辅助器ios教程)1、系统规律教程、辅助透视等服务...
aapoker透视辅助(aap... aapoker透视辅助(aapker代理)aa扑克平台(透视)原来有挂(详细有外卦挂教程)1、每一步...