• Entity Framework(01):模型优先,Linq to Entities


    一、概念:

    LINQ to Entities - ADO.NET | Microsoft Docs

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

    1、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文件。无论哪种情况,你都可以在基础数据库更改时自动更新模型,并为应用程序生成对象层代码。

    image

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

    image

    image

    三、新建ObjectContext 和EntityObject

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

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

    image

    image

    image

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

    image

    Oracle设置项目属性:

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

    image

    注意:在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实体数据模型)

    image

    image

    自动生成:

    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

    image 

  • 相关阅读:
    类方法代码重构寻找坏味道
    迭代二分查找二分查找
    系统牛逼[置顶] 使用RAMP理解内在动机 Understanding Intrinsic Motivation with RAMP
    对象服务器Webservices获取天气
    手机服务器Android消息推送(二)基于MQTT协议实现的推送功能
    概率小数2013年阿里巴巴暑期实习招聘笔试题目(不完整,笔试时间:2013.5.5)
    像素颜色JavaFX示例简易图片处理工具
    算法队列SPFA算法详解
    选择文件Eclipse制作jar包
    nullnull推箱子
  • 原文地址:https://www.cnblogs.com/springsnow/p/13230057.html
Copyright © 2020-2023  润新知