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

Entity?Framework使用ObjectContext類

 更新時間:2022年06月13日 11:37:18   作者:springsnow  
這篇文章介紹了Entity?Framework使用ObjectContext類的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

一、ObjectContext對象上下文

Entity SQL 語言 - ADO.NET | Microsoft 官當文檔

ObjectContext提供了管理數(shù)據(jù)的功能。

1、ObjectContext和DbContext的對比

1、從DbContext訪問底層的ObjectContext

AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();
ObjectContext ctxObj = ((IObjectContextAdapter)ctxNew).ObjectContext;

2、創(chuàng)建ObjectSet

AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();//對象上下文
ObjectContext ctxObj = ((IObjectContextAdapter)ctx).ObjectContext;

ObjectSet objectSet = ctxObj.CreateObjectSet("Person");

2、ObjectContext類的實例封裝的內(nèi)容

ObjectContext 封裝.NET Framework和數(shù)據(jù)庫之間的連接。此類用作“創(chuàng)建”、“讀取”、“更新”和“刪除”操作的網(wǎng)關。

ObjectContext是一個類,用于管理所有數(shù)據(jù)庫操作(如數(shù)據(jù)庫連接),并管理實體模型的各種實體。我們可以說ObjectContext是訪問或與概念模型中定義的實體一起工作的主要類。

  • 到數(shù)據(jù)庫的連接,以 EntityConnection 對象的形式封裝。
  • 描述該模型的元數(shù)據(jù),以 MetadataWorkspace 對象的形式封裝。
  • 用于管理緩存中持久保存的對象的 ObjectStateManager 對象。

3、類的結(jié)構(gòu):

ObjectContext類的成員方法

  • Attach(string,object):將實體對象附加到指定的實體容器中
  • AddObject(string,object):將實體對象添加到制定的實體容器中
  • Detach(object):移除指定的實體對象
  • DeleteObject(object):刪除指定的實體對象
  • GetObjectByKey(System.Data.EntityKey key):通過主鍵KEY從ObjectStateManager中檢索對象(如果存在);否則從存儲區(qū)中檢索。
  • TryGetObjectByKey(System.Data.EntityKey,out object):嘗試從指定實體主鍵返回該實體
  • ApplyPropertyChanges(string,object):將以指派的實體對象屬性的更改應用到容器中對應的原對象。
  • AcceptAllChanges():接受所有對該實體對象的更改
  • SaveChanges(bool):將所有更新持久保存到存儲區(qū)中。參數(shù)是客戶端事務支持所需的參數(shù)。參數(shù)為true則在更新后自動將更改應用到ObjectStateManager中的實體。如果為false,則在更新后還需要調(diào)用AcceptAllChanges()以便更新ObjectStateManager中的實體。
  • Refresh(System.Data.Objects.RefreshMode refreshMode, object entity):按指定持久更新模式,使用指定實體的存儲區(qū)數(shù)據(jù)更新ObjectStateManager。
  • CreateQuery(string,params ObjectParameter[]):從給定的查詢字符串創(chuàng)建ObjectQuery對象。
  • ExecuteFunction(string,params ObjectParameter[]):對默認容器執(zhí)行給定的函數(shù)。

二、實體對象查詢:linq to Entities

并非所有的LINQ標準查詢運算符都支持 linq to Entities 查詢。

1、AddObject :添加實體

將實體添加到集合中,創(chuàng)建實體時,狀態(tài)為EntityState.Detached。

當調(diào)用AddObject將實體添加到Context時,狀態(tài)為EntityState.Added

myContext context = new myContext(); 
myTab r = new myTab();
r.ID = 10;
r.a = "wxwinter"; 
Console.WriteLine(r.EntityState); //print:Detached 
context.AddTomyTab(r); 
Console.WriteLine(r.EntityState); //print:Added 
context.SaveChanges();

myContext context = new myContext(); 
myTab newrow = new myTab() { a = "wxd", b = "lzm", c = "wxwinter" }; 
context.AddObject("myTab",newrow); 
context.SaveChanges();

2、DeleteObject: 刪除實體

將集合中的實體添標記為刪除。

當調(diào)用Context.DeleteObject時,并不是將實體移除集合,而是將實體添標記為EntityState.Deleted ,在下次調(diào)用SaveChanges()方法時跟新數(shù)據(jù)庫

myContext context = new myContext(); 
myTab r = context.myTab.First(p=>p.ID==1); 
Console.WriteLine(r.EntityState); //print:Unchanged 
context.DeleteObject(r); 
Console.WriteLine(r.EntityState); //print:Deleted 
context.SaveChanges();

3、Detach: 分離實體

將實體從Context中分離,將狀態(tài)標記為EntityState.Detached 。

myContext context = new myContext();  
myTab r = myTab.CreatemyTab(22);  
Console.WriteLine(r.EntityState); //print:Detached  
context.AddTomyTab(r);  
Console.WriteLine(r.EntityState); //print:Added  
context.Detach(r); 
Console.WriteLine(r.EntityState); //print: Detached

4、修改實體

可以直接修在實體對象上修改。

當修改在Context中的實體時,會將實體的狀態(tài)標記為EntityState.Modified

myContext context = new myContext();  
myTab r = context.myTab.First(p=>p.ID==1);
Console.WriteLine(r.EntityState); //print:Unchanged
r.a = "wxwinter";
Console.WriteLine(r.EntityState); //print:Modified  
context.SaveChanges();

5、保存到數(shù)據(jù)庫

int changes = 0;
try
{
    changes += ctx.SaveChanges();
}
catch (OptimisticConcurrencyException ex)
{
    ctx.Refresh(System.Data.Objects.RefreshMode.ClientWins, ex.StateEntries);
    changes += ctx.SaveChanges();
}
Console.WriteLine("實體改變數(shù)量" + changes);

三、對象狀態(tài)管理

1、ObjectStateEntry對象狀態(tài)實體

ObjectStateEntry維護實體實例或關系實例的狀態(tài)(已添加、已刪除、已分離、已修改或未更改)、鍵值和原始值。還管理已修改屬性的列表。

其包含以下方法:

  • AcceptChanges():接受當前值作為原始值,并將實體標記為Unchanged()。
  • Delete():將實體標記為Deleted()。如果實體處于Added()()()狀態(tài),它將為Detached()。
  • GetModifiedProperties():返回標記為Modified()的屬性名稱。
  • SetModified():將狀態(tài)設置為Modified()。
  • SetModifiedProperty():將指定的屬性標記為Modified()。

2、ObjectStateManager對象狀態(tài)管理器

ObjectStateManager用于維護對象映射、對象狀態(tài)/標識管理以及實體實例或關系實例的持久性。

1、GetObjectStateEntries:獲取給定EntityState的ObjectStateEntry集合。

IEnumerable<ObjectStateEntry> oseList = ctx.ObjectStateManager.GetObjectStateEntries(EntityState.Added);
foreach (ObjectStateEntry ose in oseList)
{
    Console.WriteLine("{0},{1},{2},{3}", ose.State, ose.CurrentValues["ID"], ose.EntitySet.Name, ose.Entity);
}

2、GetObjectStateEntry:獲取給定的EntityKey對應的ObjectStateEntry

myContext ctx = new myContext();
myTab r = ctx.myTab.First(p => p.ID == 1);
r.a = "wxwinter";
ObjectStateEntry ose = context.ObjectStateManager.GetObjectStateEntry(r.EntityKey);

Console.WriteLine(ose.State);
foreach (string pr in ose.GetModifiedProperties())
{
    Console.WriteLine(pr);
    Console.WriteLine("CurrentValues :{0}", ose.CurrentValues[pr]);
    Console.WriteLine("OriginalValues:{0}", ose.OriginalValues[pr]);
}

五、ObjectQuery對象查詢

  • ObjectQuery 提供了一個管理[實體對象]集合的方法。
  • ObjectQuery對ObjectContext進行了封裝。

可以在對象查詢中使用esql

  • e關鍵字:“e”出現(xiàn)在 ESQL 中, 由 ObjectQuery.Name 屬性設定,用于標示源查詢對象(ObjectQuery)的名稱,可以將這個默認值 "e" 改成其他字符串。
  • value關鍵字:value后只能返回一個成員。
  • 查詢參數(shù):ObjectParameter v1 = new ObjectParameter("v1", 3);

訪問方式

1、Context.CreateQuery("esql")創(chuàng)建ObjectQuery。

可以通過ObjectContext.CreateQuery("esql")的方式創(chuàng)建ObjectQuery。

AdventureWorks2012Entities ctx = new AdventureWorks2012Entities();//對象上下文
ObjectContext ctxObj = (ctx as IObjectContextAdapter).ObjectContext;
// ObjectQuery query = new ObjectQuery("select * from..", ctxObj);  
ObjectQuery queryTab = ctxObj.CreateQuery("select  value e  from Person as e  where e.FirstName like 'A%'"); 
Console.WriteLine(queryTab .ToTraceString());
foreach (Person r in queryTab )
{
    Console.WriteLine(r.FirstName);
}

2、new ObjectQuery(ObjectContext,"esql")創(chuàng)建ObjectQuery

可以通過new ObjectQuery(ObjectContext,"esql")的方式創(chuàng)建ObjectQuery,會跟據(jù)SQL字串的不同,得到具體的ObjectQuery<值類型>,或ObjectQuery或ObjectQuery<實體>

string econString = @"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""";
EntityConnection econ = new EntityConnection(econString);
ObjectContext ctxObj = new ObjectContext(econ);//使用ObjectContext封裝EntityConnection 
ObjectQuery queryTab = new ObjectQuery("select  e.FirstName,e.LastName  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'", ctxObj );

foreach (var r in queryTab)
{

    System.Console.WriteLine("{0},{1}", r[0].ToString(), r[1].ToString());

}

3、ObjectQuery<簡單類型>

ObjectQuery<int> queryTab = new ObjectQuery<int>("select value Count(e.BusinessEntityID) from AdventureWorks2012Entities.Person as e", ctxObj );
foreach (var r in queryTab)
{
    System.Console.WriteLine("個數(shù):{0}", r.ToString());
}

4、Linq查詢

ObjectQuery queryTab = ctxObj.CreateQuery("select  value e  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'");//這以后的linq查詢條件可合并為一個SQL
IQueryable queryTab2 = queryTab.Where(p => p.FirstName.StartsWith("A")).OrderBy(p => p.LastName);
foreach (var r in queryTab2)
{
    System.Console.WriteLine("{0},{1}", r.FirstName, r.LastName);
}

5、ToTraceString():跟蹤SQL語句

這個方法用于追蹤所執(zhí)行的SQL語句,通過此方法我們可以獲取所執(zhí)行的SQL語句,以便我們查看、分析具體執(zhí)行的SQL語句。

6、ObjectQuery.Execute()方法

返回ObjectResult結(jié)果集

ObjectQuery queryTab = ctxObj .CreateQuery("select  value e  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'");
ObjectResult resultTab = queryTab.Execute(MergeOption.NoTracking);
foreach (var r in resultTab)
{
    System.Console.WriteLine("{0},{1}", r.FirstName, r.LastName);
}

7、Entity Client方式查詢

不需要使用ObjectContext實例!! Entity Client使用esql。

//不需要使用ObjectContext實例??!

string esql = "select  value e  from AdventureWorks2012Entities.Person as e  where e.FirstName like 'A%'";//獲取所有列,不能使用Select * 
 EntityConnection conn = new EntityConnection("name=AdventureWorks2012Entities");
 conn.Open();
 EntityCommand cmd = conn.CreateCommand();
 cmd.CommandText = esql;
 EntityDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);
 while (dr.Read())
 {
     MessageBox.Show(dr.GetValue(0) + "," + dr.GetValue(1));
 }

到此這篇關于Entity Framework使用ObjectContext類的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 如何在datagridview中添加button按鈕

    如何在datagridview中添加button按鈕

    這篇文章主要介紹了如何在datagridview中添加button按鈕問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 基于WPF實現(xiàn)PDF的顯示與轉(zhuǎn)換

    基于WPF實現(xiàn)PDF的顯示與轉(zhuǎn)換

    這篇文章為大家詳細主要介紹了如何基于WPF實現(xiàn)PDF的顯示并轉(zhuǎn)換成圖片,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-12-12
  • PC藍牙通信C#代碼實現(xiàn)

    PC藍牙通信C#代碼實現(xiàn)

    這篇文章主要為大家詳細介紹了PC藍牙通信C#代碼實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • C#實現(xiàn)程序等待延遲執(zhí)行的方法

    C#實現(xiàn)程序等待延遲執(zhí)行的方法

    這篇文章主要介紹了C#實現(xiàn)程序等待延遲執(zhí)行的方法,涉及C#動態(tài)鏈接庫的使用及延遲的實現(xiàn)技巧,需要的朋友可以參考下
    2015-09-09
  • 基于DateTime.ParseExact方法的使用詳解

    基于DateTime.ParseExact方法的使用詳解

    本篇文章是對DateTime.ParseExact方法的使用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • c#簡單工廠、工廠方法與抽象工廠的區(qū)別分析

    c#簡單工廠、工廠方法與抽象工廠的區(qū)別分析

    看了網(wǎng)絡上很多關于設計模式的方法,有的模式看起來相似,但本質(zhì)還是區(qū)別很大的.像簡單工廠,工廠方法和抽象工廠就有很明顯的區(qū)別.
    2013-03-03
  • C#使用InstallerProjects打包桌面應用程序的完整步驟

    C#使用InstallerProjects打包桌面應用程序的完整步驟

    這篇文章主要給大家介紹了關于C#使用InstallerProjects打包桌面應用程序的完整步驟,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C#具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • FileStream常用的屬性與方法總結(jié)

    FileStream常用的屬性與方法總結(jié)

    本篇文章主要是對FileStream常用的屬性與方法進行了詳細的總結(jié)介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • Unity UGUI的ToggleGroup選項組件介紹使用

    Unity UGUI的ToggleGroup選項組件介紹使用

    這篇文章主要為大家介紹了Unity UGUI的ToggleGroup選項組件介紹使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • C#實現(xiàn)歸并排序

    C#實現(xiàn)歸并排序

    這篇文章介紹了C#實現(xiàn)歸并排序的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04

最新評論