天天看点

IEnumerable vs IQueryable

        初学Entity Framework时,根本没有意识到IQueryable。那时从数据库查数据都是先把所有记录取出来,放内存上,再对这些内存上的数据进行筛选。数据少的时候,这种方法也马马虎虎能用。但数据一多,性能问题突显。

        IEnumberable 和 IQueryable的差异。

        来源:IEnumerable VS IQueryable

        IEnumberable适用于查询内存中的集合数据。如List,Arrary,Linq to Object,Linq to Xml

        当它用于查询数据库中的数据时,过程如下:

  1. 在服务器端(数据库)执行查询搜索(不带复杂的筛选条件)
  2. 将查到的数据载入到客户端的内存中
  3. 对客户端内存中的数据进行筛选

        因为IEnumerable不支持懒加载。

        IQueryable适用于查询内存外的集合数据。如数据库,Linq to Sql,Service

        当它用于查询数据库中的数据时,会将查询和所有筛选都放在服务端(数据库)完成。

        因为IQueryable支持懒加载。(所以适用于分页的场景)