了解ADO.NET实体框架查询
创始人
2024-06-18 13:21:46
0

对于ADO.NET实体框架我们还是有一定的了解的,这里我们就针对实体框架中的ADO.NET对象查询做出细致的介绍。ObjectQuery 泛型类表示一个查询,此查询返回由零个或零个以上类型化实体对象组成的集合。对象查询总是属于现有对象上下文。

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

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

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

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

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

以下留心事项适用于查询投影:可以对 ObjectQuery 执行 原始化,ADO.NET实体框架使之表示单个标量结果而不是标量结果集合。某些扩展要领要求运用集合结果作为输入。在这种情况下,当调用其中的一个要领时将引发 ArgumentException,如下面的示例所示。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...