快速业务通道

LINQ学习笔记:LINQ to SQL实体类

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-03-13

这种情况延迟加载将会被应用,并在每一个循环中都会和数据库交互.虽然可能引起性能问题, 但当你希望有选择性的执行内部循环的时候,这种做法可以带来你所需要的好处,例如:

   1: foreach (Customer c in dataContext.Customers)
   2:  
   3:   if (myWebService.yourMethod (c.ID)) // 商业逻辑判断
   4:  
   5:     foreach (Purchase p in c.Purchases) // 数据库往返
   6:  
   7:       Console.WriteLine (“output something”);

DataLoadOptions

DataLoadOption有两个主要的用途:

1.允许你预先设置一个EntitySet关联的过滤器

2.允许你立即加载对应的EntitySets以便减少

预先过滤

下面的例子演示如何使用DataLoadOptions的AssociateWith方法:

   1: DataLoadOptions options = new DataLoadOptions();
   2:  
   3: options.AssociateWith
   4:  
   5:   (c => c.Purchases.Where (p => p.Price > 456));
   6:  
   7: dataContext.LoadOptions =options;

代码段指示DataContext实例总是使用给定的断言来过滤customer对应的purchase采购订单.AssociateWith并不会改变延迟执行的语义, 它只是简单的对一个特定的关系应用了一个过滤器而已.

热加载(Eager Loading)

DataLoadOptions的另外一个用途是对特定的EntitySets热加载其对应的parents, 假设你想在一次数据库往返中加载所有的customers及其对应的purchase,示例如下:

   1: DataLoadOptions options = new DataLoadOptions();
   2:  
   3: options.LoadWith (c =>c.Purchases);
   4:  
   5: dataContext.LoadOptions = options;
   6:  
   7: foreach (Customer c in dataContext.Customers)
   8:  
   9:   foreach (Purchase p in c.Purchases)
  10:  
  11:     Console.WriteLine (c.Name + ” bought a “ + p.Description);

该代码段表示当读取Customer的时候,其对应的Purchases也应该在同一时间被加载, 你甚至可以进一步记载PurchaseItem:

   1: options.LoadWith  (c => c.Purchases);
   2:  
   3: options.LoadWith (p =>p.PurchaseItems);

我们也可以将AssociateWith和LoadWith组合在一起使用, 如下所示:

   1: options.LoadWith  (c => c.Purchases);
   2:  
   3: options.AssociateWith (c => c.Purchases.Where (p => p.Price > 456));

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号