• IEnumerable与IQueryable延迟加载


    >Enumable类型是linq to object 是一个很特殊的类型 这个类型的数据源都是在程序的内存中

    >Queryable类型是 Linq to sql 对数据库进行操作都是这个类型 这个类型会生成表达式目录树
    在这里插入图片描述
    在这里插入图片描述

    using (CustomerDbContext context = new CustomerDbContext())
                                {
                                    Console.WriteLine("****************IQueryable*******************");
    
                                    IQueryable<Commodity> commodity = context.Commodities.Where(c => c.Id == 20001);
    
                                    commodity.ToList();
                                    commodity.ToArray();
                                    commodity.ToDictionary();  //都可以去去加载数据
    
                                        commodityquery = context.Commodities
                                            .Where(c => c.Id == 20001)
                                            .AsQueryable()
                                            .Where(c => c.Title.Contains("test"))
                                            .Where(c => c.Title.Contains("1"));
    
                                    Console.WriteLine("****************IQueryable*******************");
                                    foreach (var item in commodityquery)         //具体使用数据时候才去加载,延迟加载        会根据你的条件拼装sql  在   数据库中    精准的查你的数据
                                    {
                                        Console.WriteLine(item.Title);
                                    }
                                }
    
                                Console.WriteLine("****************IEnumerable*******************");
                                IEnumerable<Commodity> commodityEnumer = null;
                                using (CustomerDbContext context = new CustomerDbContext())
                                {
                                    commodityEnumer = context.Commodities
                                        .Where(c => c.Id == 20001)
                                        .AsEnumerable()  //在AsEnumerable 之前的条件是到数据库中去执行,后面的Where条件是基于内存来过滤。会把所有的数据都拿出来
                                        .Where(c => c.Title.Contains("test"))
                                        .Where(c => c.Title.Contains("1"));
                                    Console.WriteLine("****************IEnumerable*******************");
                                    foreach (var item in commodityEnumer)
                                    {
                                        Console.WriteLine(item.Title);
                                    }
                                }
    
    var q = from c in dbContext.Customers
        where c.City == "London"
        select c;
    var finalAnswer = from c in q
                        orderby c.Name
                        select c;
    // 迭代被省略的最终答案序列的代码
    
    var q = (from c in dbContext.Customers
                where c.City == "London"
                select c).AsEnumerable();
    var finalAnswer = from c in q
                        orderby c.Name
                        select c;
    //迭代最终答案的代码
    

    IQueryable内置的LINQ to SQL机制,
    IEnumerable是把数据库对象强制转为IEnumerable形式的序列,并把排序等工作放在本地完成。
    有些功能用IQueryable实现起来要比用IEnumerable快得多。
    用IEnumerable所写的那个版本必须在本地执行,系统要把lambda表达式编译到方法里面,并在本地计算机上面运行,这意味着无论有待处理的数据在不在本地,都必须先获取过来才行。
    用IQueryable实现出来的版本则会解析表达式树,在解析的时候,系统会把这棵树所表示的逻辑转换成provider能够操作的格式,并将其放在 离数据最近的地方 去执行
    如果在性能与健壮这两项因素之间更看重后者,那么可以把查询结果明确转换成IEnumerable,这样做的缺点是LINQ to SQL引擎必须把dbContext.Products中的所有内容都从数据库中获取过来。
    可以使用AsEnumerable()与AsQueryable()进行相互转换。IQueryable更适合远程执行(数据库)。

    一言以蔽之,本地数据源用IEnumerable , 并且查询的逻辑可以直接用你所定义的方法的逻辑(因为有上下文),远程数据源用IQueryable ,无法直接使用你所定义的方法的逻辑,必须先生成表达式树,查询由源对象处理。

    IQueryable :远程数据源不能直接传Func,必须用一个 Expression来包装这个Func
    IEnumerable:可以直接用本地方法。

    总结之,IEnumerable查询必须在本地执行.并且执行查询前我们必须把所有的数据加载到本地.而且更多的时候.加载的数据有大量的数据是我们不需要的无效数据.但是我们却不得不传输更多的数据.做更多的无用功.而IQueryable却总能只提供你所需要的数据.大大减少了数据的传输

    IQueryable是负责生成SQL语句的,但并不马上执行;
    IEnumerable是对任意类型的集合都能操作的,不限于是数据库还是一般的Array还是List。

    (1)Enumerable类,对继承了IEnumerable接口的集合进行扩展;

    (2)Queryable类,针对继承了IQueryable接口的集合进行扩展。

    在这里插入图片描述

    》》Enumerable类 不延迟加载,但延迟查询

    public static IEnumerable Where(this IEnumerable source, Func predicate);
    public static IEnumerable Where(this IEnumerable source, Func predicate);

    》》Queryable类 延迟加载,用到数据才加载。

    public static IQueryable Where(this IQueryable source, Expression> predicate);
    public static IQueryable Where(this IQueryable source, Expression> predicate);

    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    突破使用debugger反调试的网页
    vivado产生报告阅读分析12-时序报告8
    gpt-author v2:一款自动创作小说的AI工具
    金仓数据库 KingbaseGIS 使用手册(8.9. 栅格波段统计和分析函数、8.10. 栅格输出)
    MySQL篇---第五篇
    单元测试:会变化的定义
    Windows实现到WSL的免密登录
    在eclipse中安装properties插件PropertiesEditor及设置(附图),ASCII码转换成中文
    系统思考—啤酒游戏沙盘
    如何快速通过CMMI认证?
  • 原文地址:https://blog.csdn.net/u013400314/article/details/139301364