如何通过Entity Framework模型优先查询实现高效实体对象查询?

2026-03-31 09:401阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1991个文字,预计阅读时间需要8分钟。

如何通过Entity Framework模型优先查询实现高效实体对象查询?

目录

一、概念:EF6

二、实现的 功能:

一、安装Entity Framework 6 1. 使用VS2019 Installer安装Entity Framework 6 2. 通过Nuget安装Entity Framework 二、新建ObjectContext与EntityObject及数据模型生成数据库

目录
  • 一、概念:
    • EF6 可实现的功能:
  • 二、安装Entity Framework6
    • 1、VS2019 Installer安装“Entity Framework6 工具”
    • 2、通过Nuget安装“Entity Framework”:
  • 三、新建ObjectContext 和EntityObject
    • “根据模型生成的数据库”的设计器功能实现ModelFirst。
  • 四、实体对象查询:linq to Entities
    • 1、使用lambda表达式查询
    • 2、执行存储过程(通过“添加”-----”函数导入“的设计器功能,添加到EDM实体数据模型)
  • 五、App.conf文件
    • 六、Oracle相关工具

      一、概念:

      LINQ to Entities - ADO.NET | Microsoft 官方文档

      EF实体框架目前版本为EF6。

      EF6 可实现的功能:

      • 不依赖于任何 EF 类型的POCO实体类的映射
      • 自动更改跟踪
      • 标识解析和工作单元
      • 预先、延迟和显式加载
      • 使用LINQ(语言集成查询)转换强类型查询
      • 丰富的映射功能,可支持:
        • 一对一、一对多和多对多关系
        • 继承(每个层次结构一张表、每个类型一张表和每个具体类一张表)
        • 复杂类型
        • 存储过程
      • 通过可视化设计器创建实体模型。
      • 通过编写代码创建实体模型的“Code First”体验。
      • 既可从现有数据库生成模型,然后手动编辑,也可从头开始创建模型,然后用于生成新的数据库。
      • 与 .NET Framework 应用程序模型(包括 ASP.NET)集成,并通过数据绑定与 WPF 和 WinForms 集成。
      • 基于 ADO.NET 的数据库连接和可用于连接到 SQL Server、Oracle、MySQL、SQLite、PostgreSQL、DB2 等的众多提供程序。

      官网文档:docs.microsoft.com/zh-cn/ef/ef6/

      • Database First(数据库优先):存在的DB----------->生成Data Model .edmx文件
      • Model First(模型优先):Data Model .edmx文件----------->生成DB DLL

      POCO(plain Old CLR Object) 简单传统的CRL对象(持久性无感知),即普通类。

      比较 EF Core 和 EF6:docs.microsoft.com/zh-cn/ef/efcore-and-ef6/

      注意:EF Core 不支持对模型使用 EDMX 文件格式。 要移植这些模型,最佳方法是从应用程序的数据库中生成基于代码的新模型。

      二、安装Entity Framework6

      1、VS2019 Installer安装“Entity Framework6 工具”

      使用 Entity Framework Tools,可以从现有数据库创建概念模型,然后以图形方式直观显示和编辑概念模型。

      或者,您可以首先以图形方式创建概念模型,然后生成支持模型的数据库。

      这些工具可生成或修改.edmx文件。无论哪种情况,你都可以在基础数据库更改时自动更新模型,并为应用程序生成对象层代码。

      2、通过Nuget安装“Entity Framework”:

      三、新建ObjectContext 和EntityObject

      “根据模型生成的数据库”的设计器功能实现ModelFirst。

      通过设计器添加ADO.NET Entity Data Model项,GW.edmx生成代码:

      • 逻辑层:由SSDL(存储架构定义语言)XML定义。底层:
      • 概念层:由CSDL(概念架构定义语言)XML定义:顶层:
      • 映射层:用MSL(映射规范语言)把CSDL中定义的实体类型定义映射到SSDL上。

      Oracle设置项目属性:

      • DDL生成模板:SSDLToOracle.tt.
      • 数据库架构名称:PAMS
      • 数据库生成工作流:Generate Oracle Via T4(TPH)

      注意:在Oracle的连接中选择“Filter”可以选中某个Schema,在选择后,如果创建edmx不生效,关掉VS重启即可。

      可以增加或编辑“表映射”或”存储过程映射“,为当前选定的对象指定数据库表字段等映射。还可以为实体的每个属性指定并发模式。

      注意:通过在设计器上添加更新的“存储过程映射”,当.NET尝试更新数据时,映射的存储过程对相应的每行更新。

      默认生成DbContext和DBSet的方式:

      public partial class AdventureWorks2012Entities : DbContext { public AdventureWorks2012Entities() : base("name=AdventureWorks2012Entities") { } protected override void OnModelCreating(DbModelBuilder modelBuilder) { throw new UnintentionalCodeFirstException(); } public virtual DbSet Person { get; set; } }

      四、实体对象查询:linq to Entities

      如何通过Entity Framework模型优先查询实现高效实体对象查询?

      1、使用lambda表达式查询

      AdventureWorks2012Entities ctx = new AdventureWorks2012Entities(); ObjectContext ctxObj = ((IObjectContextAdapter)ctx).ObjectContext; ObjectSet objectSet = ctxObj.CreateObjectSet("Person"); IQueryable query1 = from e2 in objectSet//对象集 where e2.FirstName.StartsWith("A") select e2; foreach (var result in query1) { MessageBox.Show(result.FirstName); }

      2、执行存储过程(通过“添加”-----”函数导入“的设计器功能,添加到EDM实体数据模型)

      自动生成:

      public virtual int OutParam(ObjectParameter outp) { return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction("OutParam", outp); }

      1)返回存储过程的输入输出参数。

      AdventureWorks2012Entities ctx = new AdventureWorks2012Entities(); ObjectParameter outpara = new ObjectParameter("outp", typeof(string)); ctx.OutParam(outpara);//OutParam为对应的存储过程名 MessageBox.Show(outpara.Value.ToString());

      T-SQL存储过程:

      create procedure Person.OutParam @outp nvarchar output as begin set @outp='aa'; end;

      Oracle存储过程:

      create procedure pams.OutParam(outp out varchar2) is begin outp:="aa"; end;

      2)返回隐式结果集(在配置文件标记下面标记了返回类型。)

      foreach (var result in ctx.update_and_returnSalary("T1", 24000)) { Console.WriteLine(result.YGW_INT01); }

      Oracle存储过程:(T-SQL直接Select就行不用处理)

      create procedure pams.update_and_returnSalary( ID in varchar,sal in number,new_Salary out sys_refcursor ) is begin update pams.YGW_CTRL set aaa; open new_Salary for select YGW_INT01,YGW_LINE from pams.YGW_CTRL where aaa; end;

      五、App.conf文件

      <?xml version="1.0" encoding="utf-8"?> <configuration> <configSections> <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false"/> For more information on Entity Framework configuration, visit go.microsoft.com/fwlink/?LinkID=237468 <section name="oracle.manageddataaccess.client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.122.19.1, Culture=neutral, PublicKeyToken=89b483f429c47342"/> </configSections> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2"/> </startup> <entityFramework> <providers> <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer"/> </providers> <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework"> <parameters> <parameter value="mssqllocaldb"/> </parameters> </defaultConnectionFactory> </entityFramework> <connectionStrings> <add name="AdventureWorks2012Entities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string="data source=(LocalDb)\v11.0;initial catalog=AdventureWorks2012;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework"" providerName="System.Data.EntityClient"/> </connectionStrings> <system.data> <DbProviderFactories> <remove invariant="Oracle.ManagedDataAccess.Client"/> <add name="ODP.NET, Managed Driver" invariant="Oracle.ManagedDataAccess.Client" description="Oracle Data Provider for .NET, Managed Driver" type="Oracle.ManagedDataAccess.Client.OracleClientFactory, Oracle.ManagedDataAccess, Version=4.122.19.1, Culture=neutral, PublicKeyToken=89b483f429c47342"/> </DbProviderFactories> </system.data> <runtime> <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> <dependentAssembly> <publisherPolicy apply="no"/> <assemblyIdentity name="Oracle.ManagedDataAccess" publicKeyToken="89b483f429c47342" culture="neutral"/> <bindingRedirect oldVersion="4.121.0.0 - 4.65535.65535.65535" newVersion="4.122.19.1"/> </dependentAssembly> </assemblyBinding> </runtime> <oracle.manageddataaccess.client> <version number="*"> <dataSources> <dataSource alias="SampleDataSource" descriptor="(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ORCL))) "/> </dataSources> </version> </oracle.manageddataaccess.client> </configuration>

      六、Oracle相关工具

      下载:www.oracle.com/technetwork/topics/dotnet/products/index.html

      Oracle Data Access Components:(装上可对VS提供Oracle的设计时支持)www.oracle.com/database/technologies/net-downloads.html

      到此这篇关于Entity Framework模型优先与实体对象查询的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持自由互联。

      本文共计1991个文字,预计阅读时间需要8分钟。

      如何通过Entity Framework模型优先查询实现高效实体对象查询?

      目录

      一、概念:EF6

      二、实现的 功能:

      一、安装Entity Framework 6 1. 使用VS2019 Installer安装Entity Framework 6 2. 通过Nuget安装Entity Framework 二、新建ObjectContext与EntityObject及数据模型生成数据库

      目录
      • 一、概念:
        • EF6 可实现的功能:
      • 二、安装Entity Framework6
        • 1、VS2019 Installer安装“Entity Framework6 工具”
        • 2、通过Nuget安装“Entity Framework”:
      • 三、新建ObjectContext 和EntityObject
        • “根据模型生成的数据库”的设计器功能实现ModelFirst。
      • 四、实体对象查询:linq to Entities
        • 1、使用lambda表达式查询
        • 2、执行存储过程(通过“添加”-----”函数导入“的设计器功能,添加到EDM实体数据模型)
      • 五、App.conf文件
        • 六、Oracle相关工具

          一、概念:

          LINQ to Entities - ADO.NET | Microsoft 官方文档

          EF实体框架目前版本为EF6。

          EF6 可实现的功能:

          • 不依赖于任何 EF 类型的POCO实体类的映射
          • 自动更改跟踪
          • 标识解析和工作单元
          • 预先、延迟和显式加载
          • 使用LINQ(语言集成查询)转换强类型查询
          • 丰富的映射功能,可支持:
            • 一对一、一对多和多对多关系
            • 继承(每个层次结构一张表、每个类型一张表和每个具体类一张表)
            • 复杂类型
            • 存储过程
          • 通过可视化设计器创建实体模型。
          • 通过编写代码创建实体模型的“Code First”体验。
          • 既可从现有数据库生成模型,然后手动编辑,也可从头开始创建模型,然后用于生成新的数据库。
          • 与 .NET Framework 应用程序模型(包括 ASP.NET)集成,并通过数据绑定与 WPF 和 WinForms 集成。
          • 基于 ADO.NET 的数据库连接和可用于连接到 SQL Server、Oracle、MySQL、SQLite、PostgreSQL、DB2 等的众多提供程序。

          官网文档:docs.microsoft.com/zh-cn/ef/ef6/

          • Database First(数据库优先):存在的DB----------->生成Data Model .edmx文件
          • Model First(模型优先):Data Model .edmx文件----------->生成DB DLL

          POCO(plain Old CLR Object) 简单传统的CRL对象(持久性无感知),即普通类。

          比较 EF Core 和 EF6:docs.microsoft.com/zh-cn/ef/efcore-and-ef6/

          注意:EF Core 不支持对模型使用 EDMX 文件格式。 要移植这些模型,最佳方法是从应用程序的数据库中生成基于代码的新模型。

          二、安装Entity Framework6

          1、VS2019 Installer安装“Entity Framework6 工具”

          使用 Entity Framework Tools,可以从现有数据库创建概念模型,然后以图形方式直观显示和编辑概念模型。

          或者,您可以首先以图形方式创建概念模型,然后生成支持模型的数据库。

          这些工具可生成或修改.edmx文件。无论哪种情况,你都可以在基础数据库更改时自动更新模型,并为应用程序生成对象层代码。

          2、通过Nuget安装“Entity Framework”:

          三、新建ObjectContext 和EntityObject

          “根据模型生成的数据库”的设计器功能实现ModelFirst。

          通过设计器添加ADO.NET Entity Data Model项,GW.edmx生成代码:

          • 逻辑层:由SSDL(存储架构定义语言)XML定义。底层:
          • 概念层:由CSDL(概念架构定义语言)XML定义:顶层:
          • 映射层:用MSL(映射规范语言)把CSDL中定义的实体类型定义映射到SSDL上。

          Oracle设置项目属性:

          • DDL生成模板:SSDLToOracle.tt.
          • 数据库架构名称:PAMS
          • 数据库生成工作流:Generate Oracle Via T4(TPH)

          注意:在Oracle的连接中选择“Filter”可以选中某个Schema,在选择后,如果创建edmx不生效,关掉VS重启即可。

          可以增加或编辑“表映射”或”存储过程映射“,为当前选定的对象指定数据库表字段等映射。还可以为实体的每个属性指定并发模式。

          注意:通过在设计器上添加更新的“存储过程映射”,当.NET尝试更新数据时,映射的存储过程对相应的每行更新。

          默认生成DbContext和DBSet的方式:

          public partial class AdventureWorks2012Entities : DbContext { public AdventureWorks2012Entities() : base("name=AdventureWorks2012Entities") { } protected override void OnModelCreating(DbModelBuilder modelBuilder) { throw new UnintentionalCodeFirstException(); } public virtual DbSet Person { get; set; } }

          四、实体对象查询:linq to Entities

          如何通过Entity Framework模型优先查询实现高效实体对象查询?

          1、使用lambda表达式查询

          AdventureWorks2012Entities ctx = new AdventureWorks2012Entities(); ObjectContext ctxObj = ((IObjectContextAdapter)ctx).ObjectContext; ObjectSet objectSet = ctxObj.CreateObjectSet("Person"); IQueryable query1 = from e2 in objectSet//对象集 where e2.FirstName.StartsWith("A") select e2; foreach (var result in query1) { MessageBox.Show(result.FirstName); }

          2、执行存储过程(通过“添加”-----”函数导入“的设计器功能,添加到EDM实体数据模型)

          自动生成:

          public virtual int OutParam(ObjectParameter outp) { return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction("OutParam", outp); }

          1)返回存储过程的输入输出参数。

          AdventureWorks2012Entities ctx = new AdventureWorks2012Entities(); ObjectParameter outpara = new ObjectParameter("outp", typeof(string)); ctx.OutParam(outpara);//OutParam为对应的存储过程名 MessageBox.Show(outpara.Value.ToString());

          T-SQL存储过程:

          create procedure Person.OutParam @outp nvarchar output as begin set @outp='aa'; end;

          Oracle存储过程:

          create procedure pams.OutParam(outp out varchar2) is begin outp:="aa"; end;

          2)返回隐式结果集(在配置文件标记下面标记了返回类型。)

          foreach (var result in ctx.update_and_returnSalary("T1", 24000)) { Console.WriteLine(result.YGW_INT01); }

          Oracle存储过程:(T-SQL直接Select就行不用处理)

          create procedure pams.update_and_returnSalary( ID in varchar,sal in number,new_Salary out sys_refcursor ) is begin update pams.YGW_CTRL set aaa; open new_Salary for select YGW_INT01,YGW_LINE from pams.YGW_CTRL where aaa; end;

          五、App.conf文件

          <?xml version="1.0" encoding="utf-8"?> <configuration> <configSections> <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false"/> For more information on Entity Framework configuration, visit go.microsoft.com/fwlink/?LinkID=237468 <section name="oracle.manageddataaccess.client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess, Version=4.122.19.1, Culture=neutral, PublicKeyToken=89b483f429c47342"/> </configSections> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2"/> </startup> <entityFramework> <providers> <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer"/> </providers> <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework"> <parameters> <parameter value="mssqllocaldb"/> </parameters> </defaultConnectionFactory> </entityFramework> <connectionStrings> <add name="AdventureWorks2012Entities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string="data source=(LocalDb)\v11.0;initial catalog=AdventureWorks2012;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework"" providerName="System.Data.EntityClient"/> </connectionStrings> <system.data> <DbProviderFactories> <remove invariant="Oracle.ManagedDataAccess.Client"/> <add name="ODP.NET, Managed Driver" invariant="Oracle.ManagedDataAccess.Client" description="Oracle Data Provider for .NET, Managed Driver" type="Oracle.ManagedDataAccess.Client.OracleClientFactory, Oracle.ManagedDataAccess, Version=4.122.19.1, Culture=neutral, PublicKeyToken=89b483f429c47342"/> </DbProviderFactories> </system.data> <runtime> <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> <dependentAssembly> <publisherPolicy apply="no"/> <assemblyIdentity name="Oracle.ManagedDataAccess" publicKeyToken="89b483f429c47342" culture="neutral"/> <bindingRedirect oldVersion="4.121.0.0 - 4.65535.65535.65535" newVersion="4.122.19.1"/> </dependentAssembly> </assemblyBinding> </runtime> <oracle.manageddataaccess.client> <version number="*"> <dataSources> <dataSource alias="SampleDataSource" descriptor="(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ORCL))) "/> </dataSources> </version> </oracle.manageddataaccess.client> </configuration>

          六、Oracle相关工具

          下载:www.oracle.com/technetwork/topics/dotnet/products/index.html

          Oracle Data Access Components:(装上可对VS提供Oracle的设计时支持)www.oracle.com/database/technologies/net-downloads.html

          到此这篇关于Entity Framework模型优先与实体对象查询的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持自由互联。