Linq调用LoadProducts方法
创始人
2024-06-06 14:11:31
0

学习Linq时,经常会遇到Linq调用LoadProducts方法问题,这里将介绍Linq调用LoadProducts方法问题的解决方法。

LoadWith方法和Associate With方法

这个例子说明:使用LoadWith方法来确保在检索客户信息的同时检索订单信息,在检索订单信息的同时检索订单详细信息, 仅仅访问一次数据库。即可以在一个查询中检索许多对象。使用Associate With方法来限制订单详细信息的排序规则。

  1. NorthwindDataContext db2 = new NorthwindDataContext();  
  2. DataLoadOptions ds = new DataLoadOptions();  
  3. ds.LoadWith(p => p.Orders);  
  4. ds.LoadWith(p => p.OrderDetails);  
  5. ds.AssociateWith(  
  6. p => p.OrderDetails.OrderBy(o => o.Quantity));  
  7. db2.LoadOptions = ds;  
  8. var custs = (  
  9. from c in db2.Customers  
  10. where c.City == "London"  
  11. select c);  
  12. foreach (var cust in custs)  
  13. {  
  14. foreach (var ord in cust.Orders)  
  15. {  
  16. foreach (var orderDetail in ord.OrderDetails)  
  17. {  
  18. //查询cust.CustomerID, ord.OrderID  
  19. //orderDetail.ProductID, orderDetail.Quantity  
  20. }  
  21. }  

语句描述:在原始查询过程中使用 LoadWith 请求相关数据,以便稍后在检索到的各个对象中导航时此示例还说明在急切加载关系对象时可以使用 Assoicate With 对它们进行排序。

Linq调用LoadProducts方法

这个例子在Category类里提供了一个LoadProducts分部方法。当产品的类别被加载的时候,就直接优先Linq调用LoadProducts方法来查询没有货源的产品。

  1. private IEnumerable LoadProducts(Category category)  
  2. {  
  3. //在执行LINQ to SQL的时候,这个LoadProducts分部方法  
  4. //优先加载执行,这里用存储过程也可以.   
  5. return this.Products  
  6. .Where(p => p.CategoryID == category.CategoryID)  
  7. .Where(p => !p.Discontinued);  

执行下面的查询时,利用上面方法返回的数据进行下面的操作:

  1. NorthwindDataContext db2 = new NorthwindDataContext();  
  2. DataLoadOptions ds = new DataLoadOptions();  
  3. ds.LoadWith(p => p.Products);  
  4. db2.LoadOptions = ds;  
  5. var q = (  
  6. from c in db2.Categories  
  7. where c.CategoryID < 3 
  8. select c);  
  9. foreach (var cat in q)  
  10. {  
  11. foreach (var prod in cat.Products)  
  12. {  
  13. //查询cat.CategoryID, prod.ProductID  
  14. }  

语句描述:重写 Category 类中的分部方法LoadProducts。加载某种类别的产品时,Linq调用LoadProducts方法以加载此类别中未停产的产品。

【编辑推荐】

  1. LINQ to DataSet查询详解
  2. Linq实现XML转换浅谈
  3. Linq to SQL强类型DataContext
  4. Linq SelectMany学习经验
  5. 使用LINQ进行数据转换剖析

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...