高度概括ADO.NET对象查询

开发 后端
ADO.NET对象查询支持投影,投影返回的数据很难具体化成实体类型,文章有详细的介绍,希望对大家有帮助。

对于ADO.NET实体框架我们还是有一定的了解的,这里我们就针对实体框架中的ADO.NET对象查询做出详细的介绍。ObjectQuery 泛型类表示一个查询,此查询返回由零个或零个以上类型化实体对象组成的集合。对象查询总是属于现有对象上下文。此上下文提供了编写和执行查询所需的连接和元数据信息。

#T#类型化 ObjectContext 包含一组返回类型化 ObjectQuery 实例的属性。模型中的每个实体类型都有其中的一个属性。使用这些属性可以更容易地创建类型化 ObjectQuery 的实例。在以下方案中将执行对象查询:对其执行操作时,例如 foreach (C#) 或 For Each (Visual Basic) 枚举期间。分配用于填充 List 集合时。显式调用 Execute 方法时。调用 LINQ 查询执行运算符(例如 First 或 Any)时。有关更多信息,请参见查询生成器方法(实体框架)。

下面的查询返回一个 Contact 对象,该对象的名字和姓氏由传递的参数指定:

  1. ' Get the contacts with the specified name.  
  2. Dim contactQuery As ObjectQuery(Of Contact) = _  
  3. context.Contact _  
  4. .Where("it.LastName = @ln AND it.FirstName = @fn", _  
  5. New ObjectParameter("ln", lastName), _  
  6. New ObjectParameter("fn", firstName)) 

有关如何使用对象上下文编写和执行查询的完整示例,请参见如何:执行返回实体类型的查询(实体框架)。有关 Entity SQL 查询的更多信息,请参见 Entity SQL 语言。

查询投影

当ADO.NET对象查询用于以实体对象形式返回 实体数据模型 (EDM) 数据时,ADO.NET对象查询还支持投影,投影返回的数据很难具体化成实体类型。ObjectQuery 为返回非实体类型的投影使用 DbDataRecord 类型,该类型可以是嵌套结果或者匿名类型。简单类型(例如 Int32 或 String)与返回单个属性值的投影一起使用。

以下注意事项适用于查询投影:可以对 ObjectQuery 进行初始化,使之表示单个标量结果而不是标量结果集合。某些扩展方法要求使用集合结果作为输入。在这种情况下,当调用其中的一个方法时将引发 ArgumentException,如下面的示例所示。

  1. ' Define a query projection that returns   
  2. ' a single scalar value rather than a collection.  
  3. Dim scalarQuery As ObjectQuery(Of Int32) = _  
  4. New ObjectQuery(Of Int32)("100", advWorksContext)  
  5.  
  6. ' Calling an extension method that requires a collection  
  7. ' will result in an exception.  
  8. Dim hasValues As Boolean = scalarQuery.Any()  


 

责任编辑:田树 来源: 博客
相关推荐

2009-11-12 11:17:13

2009-11-12 14:26:34

ADO.NET执行事务

2009-11-04 17:03:55

ADO.NET Exc

2009-10-29 13:34:01

ADO.NET对象

2009-11-04 12:45:33

ADO.NET Dat

2009-11-04 11:30:35

ADO.NET Dat

2009-12-18 14:27:24

ADO.NET对象

2009-12-28 13:47:31

ADO.NET对象

2009-12-21 17:35:24

ADO.NET对象

2009-11-04 10:23:05

ADO.NET Con

2009-11-13 14:38:45

ADO.NET Dat

2009-12-21 17:02:19

ADO.NET Sql

2009-11-03 15:24:14

ADO.NET对象模型

2009-06-18 09:56:44

ADO.NET对象模型

2009-12-29 10:26:43

ADO.NET实体框架

2009-12-24 16:09:42

ADO.NET数据源

2009-11-13 15:25:51

ADO.NET的对象

2009-11-04 09:43:45

ADO.NET Dat

2009-11-04 10:35:42

ADO.NET Con

2010-01-04 09:03:57

ADO.NET连接对象
点赞
收藏

51CTO技术栈公众号