IEnumerable和IQueryable接口
之间的区别
IQueryable继承于IEnumerable
IEnumerable:IEnumerable<T> 泛型类在调用自己的SKip 和 Take 等一些扩展方法之前数据就已经加载在本地内存里了,所有对于IEnumerable的过滤,排序等操作,都是在内存中发生的。
IQueryable:IQueryable<T> 是将这些方法表达式翻译成T-SQL后再向SQL服务器发送命令,它并不是把所有数据都加载到内存里来才进行条件过滤,IQueryable的优势是它有表达式树,所有对于IQueryable的过滤,排序等操作,都会先缓存到表达式树中,只有当真正遍历发生的时候,才会将表达式树由IQueryProvider执行获取数据操作(解析表达式,然后执行取得结果)。
使用环境
通常在数据访问层使用IQueryable,因为可以把数据的加载延迟到业务逻辑层,很多时候,业务逻辑层不需要马上加载数据,业务逻辑层依旧可以使用延迟加载,等真正加载数据需要的时候,可以在业务逻辑层转换成IEnumerable