Entity Framework模型優先與實體對象查詢
一、概念:
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文件。無論哪種情況,你都可以在基礎數據庫更改時自動更新模型,並為應用程序生成對象層代碼。
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
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 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模型優先與實體對象查詢的文章就介紹到這瞭。希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Entity Framework系統架構與原理介紹
- Entity Framework使用ObjectContext類
- Entity Framework生成DataBase First模式
- Entity Framework使用LINQ操作實體
- 關於EF的Code First的使用以及踩坑記錄