Entity Framework模型优先与实体对象查询

作者:springsnow 时间:2022-11-18 07:19:36 

一、概念:

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 等的众多提供程序。

官网文档:https://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:https://docs.microsoft.com/zh-cn/ef/efcore-and-ef6/

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

二、安装Entity Framework6

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

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

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

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

Entity Framework模型优先与实体对象查询

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

Entity Framework模型优先与实体对象查询

Entity Framework模型优先与实体对象查询

三、新建ObjectContext 和EntityObject

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

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

Entity Framework模型优先与实体对象查询

Entity Framework模型优先与实体对象查询

Entity Framework模型优先与实体对象查询

  • 逻辑层:由SSDL(存储架构定义语言)XML定义。底层:

  • 概念层:由CSDL(概念架构定义语言)XML定义:顶层:

  • 映射层:用MSL(映射规范语言)把CSDL中定义的实体类型定义映射到SSDL上。

Entity Framework模型优先与实体对象查询

Oracle设置项目属性:

  • DDL生成模板:SSDLToOracle.tt.

  • 数据库架构名称:PAMS

  • 数据库生成工作流:Generate Oracle Via T4(TPH)

Entity Framework模型优先与实体对象查询

注意:在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

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实体数据模型)

Entity Framework模型优先与实体对象查询

Entity Framework模型优先与实体对象查询

自动生成:

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 http://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相关工具

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

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

Entity Framework模型优先与实体对象查询

来源:https://www.cnblogs.com/springsnow/p/13230057.html

标签:Entity,Framework,模型,优先,实体,对象,查询
0
投稿

猜你喜欢

  • Java如何固定大小的线程池

    2021-08-30 06:18:19
  • 详解JAVA高质量代码之数组与集合

    2022-03-31 16:42:07
  • Android中实现长按修改ListView对象的内容

    2022-04-13 15:09:08
  • Spark JDBC操作MySQL方式详细讲解

    2021-05-24 12:41:51
  • Java中Cookie和Session的那些事儿

    2022-09-24 08:24:54
  • JAVA中对List进行查询

    2023-12-17 20:41:20
  • idea右键没有java class选项问题解决方案

    2023-05-29 23:38:40
  • c#图像截取实例

    2022-02-21 07:49:58
  • C#并行编程Task类用法介绍

    2021-06-26 20:58:17
  • Android自定义View实现九宫格图形解锁(Kotlin版)

    2022-04-09 11:10:50
  • Android 自定义view仿支付宝咻一咻功能

    2023-06-01 07:42:09
  • Java中一个线程执行死循环有什么后果

    2022-05-24 00:28:35
  • Android Studio中Run按钮是灰色的快速解决方法

    2023-12-27 03:06:18
  • Android使用URL读取网络资源的方法

    2023-07-27 10:56:39
  • SpringBoot新手入门的快速教程

    2021-09-28 23:23:25
  • Android仿微信列表滑动删除之可滑动控件(一)

    2021-12-24 21:15:46
  • C#实现将网址生成二维码图片方法介绍

    2022-08-14 02:31:49
  • maven下载jar包改用阿里云maven库的方法

    2023-02-13 07:41:58
  • Android6.0仿微信权限设置

    2023-03-03 09:40:30
  • android studio 4.0 新建类没有修饰符的方法

    2023-02-06 04:56:52
  • asp之家 软件编程 m.aspxhome.com