高度概括ADO.NET對象查詢
對于ADO.NET實體框架我們還是有一定的了解的,這里我們就針對實體框架中的ADO.NET對象查詢做出詳細的介紹。ObjectQuery 泛型類表示一個查詢,此查詢返回由零個或零個以上類型化實體對象組成的集合。對象查詢總是屬于現(xiàn)有對象上下文。此上下文提供了編寫和執(zhí)行查詢所需的連接和元數(shù)據(jù)信息。
#T#類型化 ObjectContext 包含一組返回類型化 ObjectQuery 實例的屬性。模型中的每個實體類型都有其中的一個屬性。使用這些屬性可以更容易地創(chuàng)建類型化 ObjectQuery 的實例。在以下方案中將執(zhí)行對象查詢:對其執(zhí)行操作時,例如 foreach (C#) 或 For Each (Visual Basic) 枚舉期間。分配用于填充 List 集合時。顯式調(diào)用 Execute 方法時。調(diào)用 LINQ 查詢執(zhí)行運算符(例如 First 或 Any)時。有關(guān)更多信息,請參見查詢生成器方法(實體框架)。
下面的查詢返回一個 Contact 對象,該對象的名字和姓氏由傳遞的參數(shù)指定:
- ' Get the contacts with the specified name.
- Dim contactQuery As ObjectQuery(Of Contact) = _
- context.Contact _
- .Where("it.LastName = @ln AND it.FirstName = @fn", _
- New ObjectParameter("ln", lastName), _
- New ObjectParameter("fn", firstName))
有關(guān)如何使用對象上下文編寫和執(zhí)行查詢的完整示例,請參見如何:執(zhí)行返回實體類型的查詢(實體框架)。有關(guān) Entity SQL 查詢的更多信息,請參見 Entity SQL 語言。
查詢投影
當(dāng)ADO.NET對象查詢用于以實體對象形式返回 實體數(shù)據(jù)模型 (EDM) 數(shù)據(jù)時,ADO.NET對象查詢還支持投影,投影返回的數(shù)據(jù)很難具體化成實體類型。ObjectQuery 為返回非實體類型的投影使用 DbDataRecord 類型,該類型可以是嵌套結(jié)果或者匿名類型。簡單類型(例如 Int32 或 String)與返回單個屬性值的投影一起使用。
以下注意事項適用于查詢投影:可以對 ObjectQuery 進行初始化,使之表示單個標量結(jié)果而不是標量結(jié)果集合。某些擴展方法要求使用集合結(jié)果作為輸入。在這種情況下,當(dāng)調(diào)用其中的一個方法時將引發(fā) ArgumentException,如下面的示例所示。
- ' Define a query projection that returns
- ' a single scalar value rather than a collection.
- Dim scalarQuery As ObjectQuery(Of Int32) = _
- New ObjectQuery(Of Int32)("100", advWorksContext)
- ' Calling an extension method that requires a collection
- ' will result in an exception.
- Dim hasValues As Boolean = scalarQuery.Any()