了解ADO.NET實(shí)體框架查詢
對(duì)于ADO.NET實(shí)體框架我們還是有一定的了解的,這里我們就針對(duì)實(shí)體框架中的ADO.NET對(duì)象查詢做出細(xì)致的介紹。ObjectQuery 泛型類表示一個(gè)查詢,此查詢返回由零個(gè)或零個(gè)以上類型化實(shí)體對(duì)象組成的集合。對(duì)象查詢總是屬于現(xiàn)有對(duì)象上下文。
類型化 ObjectContext 包含一組返回類型化 ObjectQuery 實(shí)例的屬性。模型中的每個(gè)實(shí)體類型都有其中的一個(gè)屬性。運(yùn)用這些屬性可以更容易地建立類型化 ObjectQuery 的實(shí)例。在以下方案中將執(zhí)行對(duì)象查詢:對(duì)其執(zhí)行操作時(shí),例如 foreach (C#) 或 For Each (Visual Basic) 枚舉期間。ADO.NET實(shí)體框架分配用于填充 List 集合時(shí)。顯式調(diào)用 Execute 要領(lǐng)時(shí)。調(diào)用 LINQ 查詢執(zhí)行運(yùn)算符(例如 First 或 Any)時(shí)。有關(guān)更多信息,請(qǐng)參見(jiàn)查詢生成器要領(lǐng)(實(shí)體框架)。#t#
下面的查詢返回一個(gè) Contact 對(duì)象,該對(duì)象的名字和姓氏由傳遞的參數(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)如何 運(yùn)用對(duì)象上下文編寫(xiě)和執(zhí)行查詢的完整示例,ADO.NET實(shí)體框架請(qǐng)參見(jiàn)如何 :執(zhí)行返回實(shí)體類型的查詢(實(shí)體框架)。有關(guān) Entity SQL 查詢的更多信息,請(qǐng)參見(jiàn) Entity SQL 語(yǔ)言。查詢投影
當(dāng)ADO.NET對(duì)象查詢用于以實(shí)體對(duì)象形式返回 實(shí)體數(shù)據(jù)模型 (EDM) 數(shù)據(jù)時(shí),ADO.NET對(duì)象查詢還支持投影,ADO.NET實(shí)體框架投影返回的數(shù)據(jù)很難具體化成實(shí)體類型。ObjectQuery 為返回非實(shí)體類型的投影運(yùn)用 DbDataRecord 類型,該類型可以是嵌套結(jié)果或者匿名類型。基本類型(例如 Int32 或 String)與返回單個(gè)屬性值的投影一起運(yùn)用。
以下留心事項(xiàng)適用于查詢投影:可以對(duì) ObjectQuery 執(zhí)行 原始化,ADO.NET實(shí)體框架使之表示單個(gè)標(biāo)量結(jié)果而不是標(biāo)量結(jié)果集合。某些擴(kuò)展要領(lǐng)要求運(yùn)用集合結(jié)果作為輸入。在這種情況下,當(dāng)調(diào)用其中的一個(gè)要領(lǐng)時(shí)將引發(fā) ArgumentException,如下面的示例所示。