学习Linq时,经常会遇到Linq调用LoadProducts方法问题,这里将介绍Linq调用LoadProducts方法问题的解决方法。
创新互联始终坚持【策划先行,效果至上】的经营理念,通过多达10年累计超上千家客户的网站建设总结了一套系统有效的全网推广解决方案,现已广泛运用于各行各业的客户,其中包括:公路钻孔机等企业,备受客户赞扬。
LoadWith方法和Associate With方法
这个例子说明:使用LoadWith方法来确保在检索客户信息的同时检索订单信息,在检索订单信息的同时检索订单详细信息, 仅仅访问一次数据库。即可以在一个查询中检索许多对象。使用Associate With方法来限制订单详细信息的排序规则。
- NorthwindDataContext db2 = new NorthwindDataContext();
- DataLoadOptions ds = new DataLoadOptions();
- ds.LoadWith
(p => p.Orders); - ds.LoadWith
(p => p.OrderDetails); - ds.AssociateWith
( - p => p.OrderDetails.OrderBy(o => o.Quantity));
- db2.LoadOptions = ds;
- var custs = (
- from c in db2.Customers
- where c.City == "London"
- select c);
- foreach (var cust in custs)
- {
- foreach (var ord in cust.Orders)
- {
- foreach (var orderDetail in ord.OrderDetails)
- {
- //查询cust.CustomerID, ord.OrderID
- //orderDetail.ProductID, orderDetail.Quantity
- }
- }
- }
语句描述:在原始查询过程中使用 LoadWith 请求相关数据,以便稍后在检索到的各个对象中导航时此示例还说明在急切加载关系对象时可以使用 Assoicate With 对它们进行排序。
Linq调用LoadProducts方法
这个例子在Category类里提供了一个LoadProducts分部方法。当产品的类别被加载的时候,就直接优先Linq调用LoadProducts方法来查询没有货源的产品。
- private IEnumerable
LoadProducts(Category category) - {
- //在执行LINQ to SQL的时候,这个LoadProducts分部方法
- //优先加载执行,这里用存储过程也可以.
- return this.Products
- .Where(p => p.CategoryID == category.CategoryID)
- .Where(p => !p.Discontinued);
- }
执行下面的查询时,利用上面方法返回的数据进行下面的操作:
- NorthwindDataContext db2 = new NorthwindDataContext();
- DataLoadOptions ds = new DataLoadOptions();
- ds.LoadWith
(p => p.Products); - db2.LoadOptions = ds;
- var q = (
- from c in db2.Categories
- where c.CategoryID < 3
- select c);
- foreach (var cat in q)
- {
- foreach (var prod in cat.Products)
- {
- //查询cat.CategoryID, prod.ProductID
- }
- }
语句描述:重写 Category 类中的分部方法LoadProducts。加载某种类别的产品时,Linq调用LoadProducts方法以加载此类别中未停产的产品。
分享名称:Linq调用LoadProducts方法
标题链接:http://www.mswzjz.cn/qtweb/news21/405071.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能