Ale*_*x J 27 c# linq linq-to-objects linq-to-entities
我通常用这个词entity来表示企业数据对象和在我的脑海中,linq to entities并且linq to objects是相同的.这不正确吗?
dle*_*lev 52
绝对不是这样的.
LINQ-to-Objects是一组扩展方法IEnumerable<T>,允许您对任意对象序列执行内存查询操作.这些方法在必要时接受简单的委托.
LINQ-to-Entities是一个LINQ提供程序,具有一组扩展方法IQueryable<T>.这些方法构建了一个表达式树(这就是代理实际上作为Expression<>s 传递的原因),并且提供程序将根据其对该表达式树的解析来构建SQL查询.
例如,请考虑以下查询:
var query1 = mydb.MyEntity.Select(x => x.SomeProp).Where(x => x == "Prop");
var query2 = mydb.MyEntity.Select(x => x.SomeProp).AsEnumerable().Where(x => x == "Prop");
Run Code Online (Sandbox Code Playgroud)
第一个查询将构建一个由select和where组成的表达式树,其中两个lambdas实际上被视为LambdaExpressions.LINQ-to-Entities提供程序将把它转换为选择和过滤的SQL.
第二个查询插入一个AsEnumerable(),它将强制查询的其余部分使用LINQ-to-Objects.在这种情况下,提供程序将仅基于选择生成SQL,从数据库返回所有这些记录,然后过滤将在内存中进行.显然,这可能会慢得多.
Linq to Objects 术语"LINQ to Objects"是指直接使用LINQ查询与任何IEnumerable或IEnumerable集合,而不使用中间LINQ提供程序或API,如LINQ to SQL或LINQ to XML.您可以使用LINQ查询任何可枚举的集合,例如List,Array或Dictionary.该集合可以是用户定义的,也可以由.NET Framework API返回.
从基本的意义上讲,LINQ to Objects代表了一种新的集合方法.以旧方式,您必须编写复杂的foreach循环,指定如何从集合中检索数据.在LINQ方法中,您编写描述要检索内容的声明性代码.
参考:http://msdn.microsoft.com/en-us/library/bb397919.aspx
Linq to Entity LINQ to Entities提供语言集成查询(LINQ)支持,使开发人员能够使用Visual Basic或Visual C#编写针对Entity Framework概念模型的查询.针对实体框架的查询由命令树查询表示,命令树查询针对对象上下文执行.LINQ to Entities将语言集成查询(LINQ)查询转换为命令树查询,针对实体框架执行查询,并返回可由实体框架和LINQ使用的对象.以下是创建和执行LINQ to Entities查询的过程:参考:http://msdn.microsoft.com/en-us/library/bb386964.aspx
| 归档时间: |
|
| 查看次数: |
17353 次 |
| 最近记录: |