成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Linq延遲加載詳細(xì)分析

開(kāi)發(fā) 后端
這里介紹你可以使用Linq延遲加載將額外信息的檢索操作延遲到你確實(shí)需要檢索它們時(shí)再進(jìn)行。請(qǐng)看下面的示例:檢索出來(lái)CustomerID,就根據(jù)這個(gè)ID查詢出OrderID。

Linq有很多值得學(xué)習(xí)的地方,這里我們主要介紹Linq延遲加載,包括介紹LoadWith 方法和AssociateWith方法等方面。

Linq延遲加載

在查詢某對(duì)象時(shí),實(shí)際上你只查詢?cè)搶?duì)象。不會(huì)同時(shí)自動(dòng)獲取這個(gè)對(duì)象。這就是Linq延遲加載。

例如,您可能需要查看客戶數(shù)據(jù)和訂單數(shù)據(jù)。你最初不一定需要檢索與每個(gè)客戶有關(guān)的所有訂單數(shù)據(jù)。其優(yōu)點(diǎn)是你可以使用Linq延遲加載將額外信息的檢索操作延遲到你確實(shí)需要檢索它們時(shí)再進(jìn)行。請(qǐng)看下面的示例:檢索出來(lái)CustomerID,就根據(jù)這個(gè)ID查詢出OrderID。

  1. var custs =  
  2. from c in db.Customers  
  3. where c.City == "Sao Paulo"  
  4. select c;  
  5. //上面的查詢句法不會(huì)導(dǎo)致語(yǔ)句立即執(zhí)行,僅僅是一個(gè)描述性的語(yǔ)句,  
  6. 只有需要的時(shí)候才會(huì)執(zhí)行它  
  7. foreach (var cust in custs)  
  8. {  
  9. foreach (var ord in cust.Orders)  
  10. {  
  11. //同時(shí)查看客戶數(shù)據(jù)和訂單數(shù)據(jù)  
  12. }  

語(yǔ)句描述:原始查詢未請(qǐng)求數(shù)據(jù),在所檢索到各個(gè)對(duì)象的鏈接中導(dǎo)航如何能導(dǎo)致觸發(fā)對(duì)數(shù)據(jù)庫(kù)的新查詢。

Linq延遲加載:LoadWith 方法

你如果想要同時(shí)查詢出一些對(duì)象的集合的方法。LINQ to SQL 提供了 DataLoadOptions用于立即加載對(duì)象。方法包括:
LoadWith 方法,用于立即加載與主目標(biāo)相關(guān)的數(shù)據(jù)。
AssociateWith 方法,用于篩選為特定關(guān)系檢索到的對(duì)象。

使用 LoadWith方法指定應(yīng)同時(shí)檢索與主目標(biāo)相關(guān)的哪些數(shù)據(jù)。例如,如果你知道你需要有關(guān)客戶的訂單的信息,則可以使用 LoadWith 來(lái)確保在檢索客戶信息的同時(shí)檢索訂單信息。使用此方法可僅訪問(wèn)一次數(shù)據(jù)庫(kù),但同時(shí)獲取兩組信息。
在下面的示例中,我們通過(guò)設(shè)置DataLoadOptions,來(lái)指示DataContext在加載Customers的同時(shí)把對(duì)應(yīng)的Orders一起加載,在執(zhí)行查詢時(shí)會(huì)檢索位于Sao Paulo的所有 Customers 的所有 Orders。這樣一來(lái),連續(xù)訪問(wèn) Customer 對(duì)象的 Orders 屬性不會(huì)觸發(fā)新的數(shù)據(jù)庫(kù)查詢。在執(zhí)行時(shí)生成的SQL語(yǔ)句使用了左連接。

  1. NorthwindDataContext db = new NorthwindDataContext();  
  2. DataLoadOptions ds = new DataLoadOptions();  
  3. ds.LoadWith<Customer>(p => p.Orders);  
  4. db.LoadOptions = ds;  
  5. var custs = (  
  6. from c in db2.Customers  
  7. where c.City == "Sao Paulo"  
  8. select c);  
  9. foreach (var cust in custs)  
  10. {  
  11. foreach (var ord in cust.Orders)  
  12. {  
  13. Console.WriteLine("CustomerID {0} has an OrderID {1}.",  
  14. cust.CustomerID,  
  15. ord.OrderID);  
  16. }  

語(yǔ)句描述:在原始查詢過(guò)程中使用 LoadWith 請(qǐng)求相關(guān)數(shù)據(jù),以便稍后在檢索到的各個(gè)對(duì)象中導(dǎo)航時(shí)不需要對(duì)數(shù)據(jù)庫(kù)進(jìn)行額外的往返。

Linq延遲加載:AssociateWith方法

使用 AssociateWith 方法指定子查詢以限制檢索的數(shù)據(jù)量。
在下面的示例中,AssociateWith 方法將檢索的 Orders 限制為當(dāng)天尚未裝運(yùn)的那些 Orders。如果沒(méi)有此方法,則會(huì)檢索所有 Orders,即使只需要一個(gè)子集。但是生成SQL語(yǔ)句會(huì)發(fā)現(xiàn)生成了很多SQL語(yǔ)句。

  1. NorthwindDataContext db2 = new NorthwindDataContext();  
  2. DataLoadOptions ds = new DataLoadOptions();  
  3. ds.AssociateWith<Customer>(  
  4. p => p.Orders.Where(o => o.ShipVia > 1));  
  5. db2.LoadOptions = ds;  
  6. var custs =  
  7. from c in db2.Customers  
  8. where c.City == "London"  
  9. select c;  
  10. foreach (var cust in custs)  
  11. {  
  12. foreach (var ord in cust.Orders)  
  13. {  
  14. foreach (var orderDetail in ord.OrderDetails)  
  15. {  
  16. //可以查詢出cust.CustomerID, ord.OrderID, ord.ShipVia,  
  17. //orderDetail.ProductID, orderDetail.Product.ProductName  
  18. }  
  19. }  

語(yǔ)句描述:原始查詢未請(qǐng)求數(shù)據(jù),在所檢索到各個(gè)對(duì)象的鏈接中導(dǎo)航如何以觸發(fā)對(duì)數(shù)據(jù)庫(kù)的新查詢而告終。此示例還說(shuō)明在Linq延遲加載關(guān)系對(duì)象時(shí)可以使用 Assoicate With 篩選它們。

【編輯推薦】

  1. LINQ to DataSet查詢?cè)斀?/FONT>
  2. Linq實(shí)現(xiàn)XML轉(zhuǎn)換淺談
  3. Linq to SQL強(qiáng)類型DataContext
  4. Linq SelectMany學(xué)習(xí)經(jīng)驗(yàn)
  5. 使用LINQ進(jìn)行數(shù)據(jù)轉(zhuǎn)換剖析
責(zé)任編輯:佚名 來(lái)源: IT168
相關(guān)推薦

2009-09-14 13:50:35

LINQ編程模型

2009-09-08 15:56:50

Linq使用Group

2009-09-14 16:21:34

LINQ To XML

2009-09-09 13:53:21

Linq表值函數(shù)

2009-09-25 14:23:39

2009-09-28 10:39:01

Hibernate基礎(chǔ)

2010-01-06 13:50:37

.NET Framew

2009-11-20 13:11:44

Oracle XML數(shù)

2009-06-18 14:00:51

2009-10-10 13:52:57

VB Update方法

2009-12-03 17:41:40

PHP應(yīng)用發(fā)展

2009-09-07 14:18:01

C#內(nèi)存管理

2021-10-25 19:52:52

IntentFilte

2009-03-24 09:17:58

驅(qū)動(dòng)GSMAndroid

2009-10-28 10:06:29

VB.NET With

2009-12-16 14:09:14

Visual Stud

2009-09-03 17:57:06

C#聲明事件

2009-09-04 15:43:07

C#流模型

2009-03-24 08:30:54

AndroidGoogle移動(dòng)os

2009-09-07 13:19:44

C#線程同步
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产精品高潮呻吟久久 | 米奇成人网 | 久久精品欧美一区二区三区不卡 | 成人欧美一区二区三区1314 | 一区二区在线 | 一区二区三区国产精品 | 久久亚洲国产精品日日av夜夜 | 欧美日韩精品亚洲 | 日韩在线视频一区二区三区 | 欧美99久久精品乱码影视 | 久久欧美精品 | 一区二区三区国产精品 | 日本不卡一二三 | 欧洲妇女成人淫片aaa视频 | 国产精品第2页 | 手机日韩 | 日韩国产在线 | 91精品国产综合久久婷婷香蕉 | 欧美久久一区二区 | 日韩一区二区三区视频 | 中文字幕乱码一区二区三区 | 观看av| 成人伊人网 | 手机av在线 | 亚洲一区二区三区四区五区中文 | 81精品国产乱码久久久久久 | 国产精品久久久av | 久久精品欧美一区二区三区麻豆 | 欧美一区二区三区大片 | 国产97碰免费视频 | 狠狠的操 | 成人网av | 国产欧美日韩一区二区三区在线 | 九九精品在线 | 超碰在线97国产 | 亚洲精品乱码久久久久久蜜桃91 | 午夜精品一区二区三区在线 | 国产一区二区在线播放 | 色眯眯视频在线观看 | 丁香五月网久久综合 | 久久久久久天堂 |