初学Entity Framework时,根本没有意识到IQueryable。那时从数据库查数据都是先把所有记录取出来,放内存上,再对这些内存上的数据进行筛选。数据少的时候,这种方法也马马虎虎能用。但数据一多,性能问题突显。
IEnumberable 和 IQueryable的差异。
来源:IEnumerable VS IQueryable
IEnumberable适用于查询内存中的集合数据。如List,Arrary,Linq to Object,Linq to Xml
当它用于查询数据库中的数据时,过程如下:
- 在服务器端(数据库)执行查询搜索(不带复杂的筛选条件)
- 将查到的数据载入到客户端的内存中
- 对客户端内存中的数据进行筛选
因为IEnumerable不支持懒加载。
IQueryable适用于查询内存外的集合数据。如数据库,Linq to Sql,Service
当它用于查询数据库中的数据时,会将查询和所有筛选都放在服务端(数据库)完成。
因为IQueryable支持懒加载。(所以适用于分页的场景)