zoukankan      html  css  js  c++  java
  • IQueryable和IEnumerable学习

    IQueryable和IEnumerable区别

    开始了解IQueryable和IEnumerable前,我们先看一下源码

    由上面的图片可以得知IQueryable接口继承自IEnumerable接口

    由图片可知query返回的IQueryable

    由图片可知query返回的IEnumerable
    通过在代码中打断点,通过ql server profiler监视工具进行监控,可以得知:

    (1)所有对于IEnumerable的过滤,排序等操作,都是在内存中发生的。也就是说数据已经从数据库中获取到了内存中,只是在内存中进行过滤和排序操作。
    优点:响应较快;缺点:占内存。

    (2)所有对于IQueryable的过滤,排序等操作,只有在数据真正用到的时候才会到数据库中查询。这也是Linq的延迟加载核心所在。
    优点:减少带宽 缺点:响应慢

    IQueryable的优势是它有表达式树,所有对于IQueryable的过滤,排序等操作,都会先缓存到表达式树中,只有当真正遍历发生的时候,
    才会将表达式树由IQueryProvider执行获取数据操作(解析表达式,然后执行取得结果)。

    IQueryable和IEnumerable与List的相互转换

    List转换为 IQueryable使用 AsQueryable();

    List转换为 IEnumerable使用 AsEnumerable();

    IQueryable与IEnumerable之间可以相互转换分别使用AsQueryable()、AsEnumerable()

  • 相关阅读:
    微信小程序通过CODE换取session_key和openid
    BZOJ1497[NOI2006]最大获利——最大权闭合子图
    Leetcode#149 Max Points on a Line
    IO流总结
    java基础比较好的笔记总结
    chrome web开发工具
    day 01 常量 注释 int(整型) 用户交互input 流程控制语句if
    10.2:异或树经验
    搜索+保存路径
    搜索+简单dp
  • 原文地址:https://www.cnblogs.com/moonstars/p/12470634.html
Copyright © 2011-2022 走看看