• (转载)IQueryable和IEnumerable


    第一篇:https://www.cnblogs.com/zgqys1980/p/4047315.html

    第二篇:https://www.cnblogs.com/shenbing/p/5394228.html

    第三篇:https://blog.csdn.net/ydm19891101/article/details/50969323

    第四篇:http://www.igiven.com/?p=2804  (这篇最好,阐释最详尽,最透彻)

    下面内容摘自上面第4篇博客,非本人原创:

    那么什么时候用IQueryable,什么时候用IEnumerable?

    1.Func<>谓词表达式,就是一个委托,委托一旦调用,就立即执行了,将执行结果保存在内存中。

    2.Expression是一个表达式,会存储拼接表达式树,直到在运行期最终执行。

    那么在EF中我们根据条件查询数据时,不应该把数据一次性加载到本地内存中,然后再本地内存中进行筛选,如果数据量大了,就崩溃了。

    我们需要将表达式组合好,然后再一起提交到数据库执行,返回查询结果。

    (每次在执行where查询操作符的时候IQueryProvider会为我们创建一个新的IQueryable,调用AsEnumerable()方法的时候并不会去实际取值,只是

    得到了一个IEnumerable,所以EF在查询数据时候不要先取IEnumerable再去筛选数据。执行ToList方法时才会去真正调用迭代器GetEnumerator()
    取值。真正取值时候,会去执行IQueryProvider中的Excute方法.(解析表达式,然后执行取得结果))

    这就是IQueryable的延迟加载把.

    .知识点总结

      (1) 解决查询多次的问题,因IQueryable延迟加载,当用到集合的时候,provider会解析表达式,然后生成查询,所以会走一个复杂的过程。

      (2) 本地集合:List,Array,IEnumable都是本地集合,都是缓存在里面的

      (3) 使用EF管理上下文实例的最佳选择是线程的唯一。

      (4) IEnumerable接口是一个公开枚举器,该枚举器支持在指定的集合上进行简单迭代,也就是次接口可以直接使用foreach遍历次Object。

    声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。对于本博客如有任何问题,可发邮件与我沟通,我的QQ邮箱是:3074596466@qq.com
  • 相关阅读:
    Pycharm新建第一个Django项目
    Django的MTV模型
    TCP Retransmission 连接超时
    linux系统参数调优
    企业网站架构
    基于centos7,python3.7新建第一个Django项目
    运维日常错误总结(docker)
    docker常用技巧
    DHCP服务部署
    ssh远程登录故障解决方案
  • 原文地址:https://www.cnblogs.com/CherishTheYouth/p/CherishTheYouth_20190418.html
Copyright © 2020-2023  润新知