0

我有我要传递给函数的对象列表,我想在里面计算它们。当我使用 IQueryable() 时,它不会正确计算它们,但是当我使用 IEnumerable() 时,它会计算它们。

public int functCount(IQueryable<MyObject> myLisfOfObjects)  
{
    int numberOfItems = myListOfObjects.Count(o => o.isSet); //isSet is bool property in my object
    return numberOfItem;
}

第一次调用它返回正确数量的项目,但是当我更改列表中某些元素的 isSet 属性时,它返回与第一次调用相同的数字。

public int functCount(IEnumerable<MyObject> myLisfOfObjects)  
    {
        int numberOfItems = myListOfObjects.Count(o => o.isSet); //isSet is bool property in my object
        return numberOfItem;
    }

但是当我将代码更改为此时,它每次都会返回正确的计数。

谁能解释我的区别,为什么会这样?

4

1 回答 1

4

由于您传递给其中任何一个函数的任何内容都不会导致编译错误,因此可以安全地假设它是IQueryable. 这意味着.Count()它将被重新评估为 SQL 语句并针对数据库运行(忽略您认为在内存中所做的任何更改)。然而,调用.Count()IEnumerable调用完全不同的方法,它将简单地返回内存中集合的计数。

换句话说IEnumerable<T>.Count(),andIQueryable<T>.Count()是两种完全不同的方法,做不同的事情。

于 2013-03-11T15:13:10.630 回答