我正在使用存储库模式进行数据访问实体框架 http://en.wikipedia.org/wiki/ADO.NET_Entity_Framework and LINQ http://en.wikipedia.org/wiki/Language_Integrated_Query作为非测试存储库实施的基础。当调用返回 N 条记录而不是 List 时,我看到的大多数示例都会返回 AsQueryable()。这样做有什么好处呢?
AsQueryable 只是创建一个查询,获取列表所需的指令。您可以稍后对查询进行进一步更改,例如添加新的Where 子句,这些子句会一直发送到数据库级别。
AsList 返回一个包含内存中所有项目的实际列表。如果向其中添加新的Where 线索,您将无法获得数据库提供的快速过滤功能。相反,您获取列表中的所有信息,然后过滤掉应用程序中不需要的信息。
所以基本上,归根结底就是要等到最后一刻才做出承诺。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)