Entity?Framework模型優(yōu)先與實(shí)體對象查詢
一、概念:
LINQ to Entities - ADO.NET | Microsoft 官方文檔
EF實(shí)體框架目前版本為EF6。
EF6 可實(shí)現(xiàn)的功能:
- 不依賴于任何 EF 類型的 POCO 實(shí)體類的映射
- 自動更改跟蹤
- 標(biāo)識解析和工作單元
- 預(yù)先、延遲和顯式加載
- 使用 LINQ(語言集成查詢)轉(zhuǎn)換強(qiáng)類型查詢
- 豐富的映射功能,可支持:
- 一對一、一對多和多對多關(guān)系
- 繼承(每個層次結(jié)構(gòu)一張表、每個類型一張表和每個具體類一張表)
- 復(fù)雜類型
- 存儲過程
- 通過可視化設(shè)計(jì)器創(chuàng)建實(shí)體模型。
- 通過編寫代碼創(chuàng)建實(shí)體模型的“Code First”體驗(yàn)。
- 既可從現(xiàn)有數(shù)據(jù)庫生成模型,然后手動編輯,也可從頭開始創(chuàng)建模型,然后用于生成新的數(shù)據(jù)庫。
- 與 .NET Framework 應(yīng)用程序模型(包括 ASP.NET)集成,并通過數(shù)據(jù)綁定與 WPF 和 WinForms 集成。
- 基于 ADO.NET 的數(shù)據(jù)庫連接和可用于連接到 SQL Server、Oracle、MySQL、SQLite、PostgreSQL、DB2 等的眾多提供程序。
官網(wǎng)文檔:https://docs.microsoft.com/zh-cn/ef/ef6/
- Database First(數(shù)據(jù)庫優(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 文件格式。 要移植這些模型,最佳方法是從應(yīng)用程序的數(shù)據(jù)庫中生成基于代碼的新模型。
二、安裝Entity Framework6
1、VS2019 Installer安裝“Entity Framework6 工具”
使用 Entity Framework Tools,可以從現(xiàn)有數(shù)據(jù)庫創(chuàng)建概念模型,然后以圖形方式直觀顯示和編輯概念模型。
或者,您可以首先以圖形方式創(chuàng)建概念模型,然后生成支持模型的數(shù)據(jù)庫。
這些工具可生成或修改 .edmx文件。無論哪種情況,你都可以在基礎(chǔ)數(shù)據(jù)庫更改時(shí)自動更新模型,并為應(yīng)用程序生成對象層代碼。

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


三、新建ObjectContext 和EntityObject
“根據(jù)模型生成的數(shù)據(jù)庫”的設(shè)計(jì)器功能實(shí)現(xiàn)ModelFirst。
通過設(shè)計(jì)器添加ADO.NET Entity Data Model項(xiàng),GW.edmx生成代碼:



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

Oracle設(shè)置項(xiàng)目屬性:
- DDL生成模板:SSDLToOracle.tt.
- 數(shù)據(jù)庫架構(gòu)名稱:PAMS
- 數(shù)據(jù)庫生成工作流:Generate Oracle Via T4(TPH)

注意:在Oracle的連接中選擇“Filter”可以選中某個Schema,在選擇后,如果創(chuàng)建edmx不生效,關(guān)掉VS重啟即可。
可以增加或編輯“表映射”或”存儲過程映射“,為當(dāng)前選定的對象指定數(shù)據(jù)庫表字段等映射。還可以為實(shí)體的每個屬性指定并發(fā)模式。
注意:通過在設(shè)計(jì)器上添加更新的“存儲過程映射”,當(dāng).NET嘗試更新數(shù)據(jù)時(shí),映射的存儲過程對相應(yīng)的每行更新。
默認(rèn)生成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; }
}四、實(shí)體對象查詢:linq to Entities
1、使用lambda表達(dá)式查詢
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í)行存儲過程(通過“添加”-----”函數(shù)導(dǎo)入“的設(shè)計(jì)器功能,添加到EDM實(shí)體數(shù)據(jù)模型)


自動生成:
public virtual int OutParam(ObjectParameter outp)
{
return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction("OutParam", outp);
}1)返回存儲過程的輸入輸出參數(shù)。
AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();
ObjectParameter outpara = new ObjectParameter("outp", typeof(string));
ctx.OutParam(outpara);//OutParam為對應(yīng)的存儲過程名
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)返回隱式結(jié)果集(在配置文件標(biāo)記下面標(biāo)記了返回類型。)
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相關(guān)工具
下載:https://www.oracle.com/technetwork/topics/dotnet/products/index.html
Oracle Data Access Components:(裝上可對VS提供Oracle的設(shè)計(jì)時(shí)支持) https://www.oracle.com/database/technologies/net-downloads.html

到此這篇關(guān)于Entity Framework模型優(yōu)先與實(shí)體對象查詢的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C#實(shí)現(xiàn)子窗體與父窗體通信方法實(shí)例總結(jié)
這篇文章主要介紹了C#實(shí)現(xiàn)子窗體與父窗體通信方法,實(shí)例總結(jié)了常用的四種窗體通信方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
C#實(shí)現(xiàn)獲取文本文件的編碼的一個類(區(qū)分GB2312和UTF8)
這篇文章主要介紹了C#實(shí)現(xiàn)獲取文本文件的編碼一個類,本文給出類可以自動區(qū)分GB2312和UTF8,并同時(shí)給出了使用方法,需要的朋友可以參考下2014-09-09
C# TabControl手動觸發(fā)DrawItem的實(shí)現(xiàn)
本文主要介紹了C# TabControl手動觸發(fā)DrawItem的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
解析在內(nèi)部循環(huán)中Continue外部循環(huán)的使用詳解
本篇文章是對在內(nèi)部循環(huán)中Continue外部循環(huán)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
利用C#/VB.NET實(shí)現(xiàn)將PDF轉(zhuǎn)為Word
眾所周知,PDF 文檔支持特長文件,集成度和安全可靠性都較高,可有效防止他人對 PDF 內(nèi)容進(jìn)行更改,所以在工作中深受大家喜愛。本文將分為兩部分介紹如何以編程的方式將 PDF 轉(zhuǎn)換為 Word,需要的可以參考一下2022-12-12

