Linq技巧3——何时及怎么使用预先加载

  通常情况在你的应用程序中,一旦你要查询完数据的的时候,你知道使用实体来做什么。

  假如你打印一份订单给顾客,你知道不包括组成订单的Items和Products信息,打印的信息是不完整的,所以查询时也需要加载这些信息。

  这类情况,查询时使用预先加载是很有用的。如果你需要额外的信息、实体,你可能需要提前加载这些实体数据,这会节省你的查询次数。

  正好与一些错误的观点相反,使用EF进行预先加载是可行的,而且比较方便,你可以简单地使用Include()来写自己的查询,像下面的方式:  

var reprint = (from order in ctx.Orders.Include("Items.Product") 
             where order.Customer.Name == "Fred Blogs"  
                && order.Status == "Unshipped" 
             select order).First();

  这条查询语句的意思是,这条顾客的订单包括它们的“明细”,每条“明细”又包括它们的“产品”信息。

  结果的执行语句,不需要再做过多的查询,如下:  

foreach (var item in reprint.Items) 
{ 
    Console.WriteLine("\t{0} {1} = ${2}", 
        item.Quantity, 
        item.Product.Name, 
        item.Cost); 
} 
Console.WriteLine(reprint.TotalCost);

  备注:

  这样查询不需要明确再使用Include("Items"),Include("Items.Product")的使用明确地包括了“Items”。

 

 

 

转载于:https://www.cnblogs.com/windy2008/p/3394272.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值