亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Entity?Framework模型優(yōu)先與實體對象查詢

 更新時間:2022年06月13日 11:24:18   作者:springsnow  
這篇文章介紹了Entity?Framework模型優(yōu)先與實體對象查詢,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一、概念:

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

EF實體框架目前版本為EF6。

EF6 可實現的功能:

  • 不依賴于任何 EF 類型的 POCO 實體類的映射
  • 自動更改跟蹤
  • 標識解析和工作單元
  • 預先、延遲和顯式加載
  • 使用 LINQ(語言集成查詢)轉換強類型查詢
  • 豐富的映射功能,可支持:
    • 一對一、一對多和多對多關系
    • 繼承(每個層次結構一張表、每個類型一張表和每個具體類一張表)
    • 復雜類型
    • 存儲過程
  • 通過可視化設計器創(chuàng)建實體模型。
  • 通過編寫代碼創(chuàng)建實體模型的“Code First”體驗。
  • 既可從現有數據庫生成模型,然后手動編輯,也可從頭開始創(chuàng)建模型,然后用于生成新的數據庫。
  • 與 .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(數據庫優(yōu)先):存在的DB----------->生成Data Model .edmx文件
  • Model First(模型優(yōu)先):Data Model .edmx文件----------->生成DB DLL

POCO(plain Old CLR Object) 簡單傳統(tǒng)的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,可以從現有數據庫創(chuàng)建概念模型,然后以圖形方式直觀顯示和編輯概念模型。

或者,您可以首先以圖形方式創(chuàng)建概念模型,然后生成支持模型的數據庫。

這些工具可生成或修改 .edmx文件。無論哪種情況,你都可以在基礎數據庫更改時自動更新模型,并為應用程序生成對象層代碼。

2、通過Nuget安裝“Entity Framework”:

三、新建ObjectContext 和EntityObject

“根據模型生成的數據庫”的設計器功能實現ModelFirst。

通過設計器添加ADO.NET Entity Data Model項,GW.edmx生成代碼:

  • 邏輯層:由SSDL(存儲架構定義語言)XML定義。底層:
  • 概念層:由CSDL(概念架構定義語言)XML定義:頂層:
  • 映射層:用MSL(映射規(guī)范語言)把CSDL中定義的實體類型定義映射到SSDL上。

Oracle設置項目屬性:

  • DDL生成模板:SSDLToOracle.tt.
  • 數據庫架構名稱:PAMS
  • 數據庫生成工作流:Generate Oracle Via T4(TPH)

注意:在Oracle的連接中選擇“Filter”可以選中某個Schema,在選擇后,如果創(chuàng)建edmx不生效,關掉VS重啟即可。

可以增加或編輯“表映射”或”存儲過程映射“,為當前選定的對象指定數據庫表字段等映射。還可以為實體的每個屬性指定并發(fā)模式。

注意:通過在設計器上添加更新的“存儲過程映射”,當.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、執(zhí)行存儲過程(通過“添加”-----”函數導入“的設計器功能,添加到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 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模型優(yōu)先與實體對象查詢的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C#常用排序方式總結

    C#常用排序方式總結

    在最近的項目中經常會對C#中的數據進行排序,對于基本數據類型,其排序方式比較簡單,只需要調用內置算法即可實現,但對于自定義數據類型以及自定義排序規(guī)則的情況實現起來就比較麻煩,所以在本文章中將詳細介紹一下在中C#中如何對數據進行排序,需要的朋友可以參考下
    2024-01-01
  • C#實現子窗體與父窗體通信方法實例總結

    C#實現子窗體與父窗體通信方法實例總結

    這篇文章主要介紹了C#實現子窗體與父窗體通信方法,實例總結了常用的四種窗體通信方法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09
  • C#實現獲取文本文件的編碼的一個類(區(qū)分GB2312和UTF8)

    C#實現獲取文本文件的編碼的一個類(區(qū)分GB2312和UTF8)

    這篇文章主要介紹了C#實現獲取文本文件的編碼一個類,本文給出類可以自動區(qū)分GB2312和UTF8,并同時給出了使用方法,需要的朋友可以參考下
    2014-09-09
  • C# TabControl手動觸發(fā)DrawItem的實現

    C# TabControl手動觸發(fā)DrawItem的實現

    本文主要介紹了C# TabControl手動觸發(fā)DrawItem的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • C#遞歸讀取XML菜單數據的方法

    C#遞歸讀取XML菜單數據的方法

    這篇文章主要介紹了C#遞歸讀取XML菜單數據的方法,涉及遞歸的操作技巧與C#窗體的用法,對于進行C#項目開發(fā)具有一定的參考借鑒價值,需要的朋友可以參考下
    2014-12-12
  • 解析在內部循環(huán)中Continue外部循環(huán)的使用詳解

    解析在內部循環(huán)中Continue外部循環(huán)的使用詳解

    本篇文章是對在內部循環(huán)中Continue外部循環(huán)的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • 利用C#/VB.NET實現將PDF轉為Word

    利用C#/VB.NET實現將PDF轉為Word

    眾所周知,PDF 文檔支持特長文件,集成度和安全可靠性都較高,可有效防止他人對 PDF 內容進行更改,所以在工作中深受大家喜愛。本文將分為兩部分介紹如何以編程的方式將 PDF 轉換為 Word,需要的可以參考一下
    2022-12-12
  • 深入了解c# 設計模式之簡單工廠模式

    深入了解c# 設計模式之簡單工廠模式

    這篇文章主要介紹了c# 設計模式之簡單工廠模式的的相關資料,文中代碼非常詳細,幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-06-06
  • 在GridControl控件上綁定圖片的幾種操作方式詳解

    在GridControl控件上綁定圖片的幾種操作方式詳解

    GridControl控件是經常用來綁定數據的,一般以常規(guī)的字符內容為主,有時候也會有圖片的顯示需要,這篇文章主要介紹了在GridControl控件上綁定圖片的幾種操作方式詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • 在 C# 中使用 Span<T> 和 Memory<T> 編寫高性能代碼的詳細步驟

    在 C# 中使用 Span<T> 和 Memory<

    在本文中,將會介紹 C# 7.2 中引入的新類型:Span 和 Memory,文章深入研究?Span<T>?和?Memory<T>?,并演示如何在 C# 中使用它們,需要的朋友可以參考下
    2022-08-08

最新評論