IQueryable与foreach的困惑?

 

IQueryable<Product> query = db.Products;
foreach (string keyword in keywords)
{
    string temp = keyword;
    query = query.Where(p => p.Description.Contains(temp));
}

与 

IQueryable<Product> query = db.Products;
foreach (string keyword in keywords)
{       
    query = query.Where(p => p.Description.Contains(keyword));

 有什么不同吗?

运行之后,会发现第二种写法,多次叠加得到的结果完全是相同的,而第一种写法运行的结果正常,why?

有幸在msn群里得到老赵的提点,原因如下:

IQueryable查询时,实际上是构建一个Expression Tree(表达式树),如果使用foreach迭代变量时,表达式树实际上得到的只是迭代变量的一个引用,最终运行时将只有最后一次的值,而利用一个临时变量中转一下后,对表达式而言,就是多个变量,会有不同的值

时间: 2024-09-20 06:19:19

IQueryable与foreach的困惑?的相关文章

Linq之IQueryable接口与IEnumberable区别

IEnumerable接口 公开枚举器,该枚举器支持在指定类型的集合上进行简单迭代.也就是说:实现了此接口的object,就可以直接使用foreach遍历此object:  IEnumerable 包含一个方法,GetEnumerator,返回 IEnumerator. IEnumerator 可以通过集合循环显示 Current 属性和 MoveNext 和 Reset 方法. 它是一个最优方法实现 IEnumerable 和 IEnumerator 在集合选件类启用 foreach (For

打造自己的LINQ Provider(中):IQueryable和IQueryProvider

概述 在.NET Framework 3.5中提供了LINQ 支持后,LINQ就以其强大 而优雅的编程方式赢得了开发人员的喜爱,而各种LINQ Provider更是满天飞, 如LINQ to NHibernate.LINQ to Google等,大有"一切皆LINQ"的 趋势.LINQ本身也提供了很好的扩展性,使得我们可以轻松的编写属于自己的 LINQ Provider. 本文为打造自己的LINQ Provider系列文章第二篇,主 要详细介绍自定义LINQ Provider中两个最重

编写高质量代码改善C#程序的157个建议[IEnumerable&lt;T&gt;和IQueryable&lt;T&gt;、LINQ避免迭代、LINQ替代迭代]

原文:编写高质量代码改善C#程序的157个建议[IEnumerable<T>和IQueryable<T>.LINQ避免迭代.LINQ替代迭代] 前言 本文已更新至http://www.cnblogs.com/aehyok/p/3624579.html .本文主要学习记录以下内容: 建议29.区别LINQ查询中的IEnumerable<T>和IQueryable<T> 建议30.使用LINQ取代集合中的比较器和迭代器 建议31.在LINQ查询中避免不必要的迭代

IQueryable接口与IEnumerable接口比较

         今天写代码的时候调到IQueryable里面看它的方法,发现它是实现IEnumerable接口的,then i'm confused!                       要区分他俩还是先写段代码来看看吧~                  我们拿出以前那个练习EF增删改查的代码改一改:             #region 查询单个实体 using (var dbContext = new SecondChargeEntities())//先创建访问数据库的入口 {

.net初学者的困惑之AspNetPager控件的困惑

问题描述 后台usingSystem;usingSystem.Data;usingSystem.Configuration;usingSystem.Collections;usingSystem.Web;usingSystem.Web.Security;usingSystem.Web.UI;usingSystem.Web.UI.WebControls;usingSystem.Web.UI.WebControls.WebParts;usingSystem.Web.UI.HtmlControls;u

Java for-each循环使用难题2例(高级使用方法)_java

Java中,for-each循环简化了任何Collection或array的遍历过程,但并不是每个Java程序员都了解本文将要描述的for-each 循环的一些细节.与 Java5 发布的其他术语:释放别名泛型,自动封装和可变参数不同,Java开发者对for-each循环的使用比任何其他特性更加频繁,但当问及高级的for-each循环怎样工作,或什么是在for-each循环中使用Collection时的基本需求时,就不是每个人都能够回答的了. 本篇教程和例子旨在通过深入研究for-each 循环

三层的困惑

这个问题困惑我已经很久了,从开始学习.NET到现在-- 写三层的时候,遇到这样的情况怎么办?User{    int UserId,    String UserName}Article{    int Id,    int UserId,//作者ID    String Title,} 现在有个表格要显示如下两列:ArticleTitle,UserName其中每一行对应每一篇文章.在三层架构中,应该这样做吧: //用于存储最后显示于表示层的数据,相当于Fascade.这是页面上用于绑定在Rep

.NET深入解析LINQ框架(四:IQueryable、IQueryProvider接口详解)

阅读目录: 1.开篇介绍 2.扩展Linq to Object (应用框架具有查询功能) 2.1.通过添加IEnumerable<T>对象的扩展方法 2.2.通过继承IEnumerable<T>接口 2.3.详细的对象结构图 3.实现IQueryable<T> .IQueryProvider接口 3.1.延迟加载IEnumertor<T>对象(提高系统性能) 3.2.扩展方法的扩展对象之奥秘(this IQueryable<TSource> so

.NET深入解析LINQ框架(五:IQueryable、IQueryProvider接口详解)

阅读目录: 1.环路执行对象模型.碎片化执行模型(假递归式调用) 2.N层对象执行模型(纵横向对比链式扩展方法) 3.LINQ查询表达式和链式查询方法其实都是空壳子 4.详细的对象结构图(对象的执行原理) 5.IQueryable<T>与IQueryProvider一对一的关系能否改成一对多的关系 6.完整的自定义查询 1]. 环路执行对象模型.碎片化执行模型(假递归式调用) 这个主题扯的可能有点远,但是它关系着整个LINQ框架的设计结构,至少在我还没有搞懂LINQ的本意之前,在我脑海里一直频