Gewusst wie: Ausführen einer Abfrage, die einen anonymen Typ zurückgibt (Entity Framework)
In diesem Thema wird anhand von Beispielen gezeigt, wie Abfragen ausgeführt werden, die eine Auflistung von Instanzen eines anonymen Typs zurückgeben, wie beispielsweise Auflistung, Zeile und Verweis. In diesen Beispielen ist das Abfrageergebnis eine Auflistung von Zeilentypen. Weitere Informationen finden Sie unter Typsystem (Entity SQL). Das gleiche Beispiel wird mit der Verwendung jeder der folgenden Entity Framework-Abfragetechnologien gezeigt:
LINQ to Entities
Entity SQL mit ObjectQuery<T>
Abfrage-Generator-Methoden von ObjectQuery<T>
Die Beispiele in diesem Thema beruhen auf dem AdventureWorks Sales-Modell. Um den Code in diesem Beispiel auszuführen, müssen Sie Ihrem Projekt bereits das "AdventureWorks Sales"-Modell hinzugefügt und das Projekt zur Verwendung von Entity Framework konfiguriert haben. Verwenden Sie dazu die Verfahren in Gewusst wie: Manuelles Konfigurieren eines Entity Framework-Projekts und Gewusst wie: Manuelles Definieren eines Entity Data Model (Entity Framework). Sie können auch den Assistenten für Entity Data Model zum Definieren des "AdventureWorks Sales"-Modells verwenden. Weitere Informationen finden Sie unter Gewusst wie: Verwenden des Assistenten für Entity Data Model (Entity Framework).
Beispiel
Im Folgenden finden Sie das LINQ-to-Entities-Beispiel:
Using AWEntities As New AdventureWorksEntities
Dim products As ObjectQuery(Of Product) = AWEntities.Product
Dim query = _
From product In products _
Select New With _
{ _
.ProductId = product.ProductID, _
.ProductName = product.Name _
}
Console.WriteLine("Product Info:")
For Each productInfo In query
Console.WriteLine("Product Id: {0} Product name: {1} ", _
productInfo.ProductId, productInfo.ProductName)
Next
End Using
using (AdventureWorksEntities AWEntities = new AdventureWorksEntities())
{
ObjectQuery<Product> products = AWEntities.Product;
var query =
from product in products
select new
{
ProductId = product.ProductID,
ProductName = product.Name
};
Console.WriteLine("Product Info:");
foreach (var productInfo in query)
{
Console.WriteLine("Product Id: {0} Product name: {1} ",
productInfo.ProductId, productInfo.ProductName);
}
}
Im Folgenden finden Sie das Entity SQL-Beispiel:
Using advWorksContext As AdventureWorksEntities = New AdventureWorksEntities
Dim commandText As String = "SELECT p.ProductID, p.Name FROM " & _
"AdventureWorksEntities.Product as p"
Try
Dim query As New ObjectQuery(Of DbDataRecord)(commandText, advWorksContext)
For Each result As DbDataRecord In query
Console.WriteLine("ID {0} Name {1}", result.Item(0), result.Item(1))
Next
Catch ex As EntityException
Console.WriteLine(ex.ToString())
Catch ex As InvalidOperationException
Console.WriteLine(ex.ToString())
End Try
End Using
using (AdventureWorksEntities advWorksContext =
new AdventureWorksEntities())
{
string myQuery = @"SELECT p.ProductID, p.Name FROM
AdventureWorksEntities.Product as p";
try
{
foreach (DbDataRecord rec in
new ObjectQuery<DbDataRecord>(myQuery, advWorksContext))
{
Console.WriteLine("ID {0}; Name {1}", rec[0], rec[1]);
}
}
catch (EntityException ex)
{
Console.WriteLine(ex.ToString());
}
catch (InvalidOperationException ex)
{
Console.WriteLine(ex.ToString());
}
}
Im Folgenden wird ein Beispiel für die Abfrage-Generator-Methode dargestellt.
Using advWorksContext As AdventureWorksEntities = _
New AdventureWorksEntities
Try
' Use the Select method to define the projection.
Dim query As ObjectQuery(Of DbDataRecord) = _
advWorksContext.Product.Select("it.ProductID, it.Name")
' Iterate through the collection of data rows.
For Each result As DbDataRecord In query
Console.WriteLine("ID{0}: Name {1}", _
result.Item(0), result.Item(1))
Next
Catch ex As EntitySqlException
Console.WriteLine(ex.ToString())
End Try
End Using
using (AdventureWorksEntities advWorksContext =
new AdventureWorksEntities())
{
try
{
// Use the Select method to define the projection.
ObjectQuery<DbDataRecord> query =
advWorksContext.Product.Select("it.ProductID, it.Name");
// Iterate through the collection of data rows.
foreach (DbDataRecord rec in query)
{
Console.WriteLine("ID {0}; Name {1}", rec[0], rec[1]);
}
}
catch (EntitySqlException ex)
{
Console.WriteLine(ex.ToString());
}
}
Siehe auch
Aufgaben
Gewusst wie: Ausführen einer Abfrage, die einen Entitätstyp zurückgibt (Entity Framework)
Gewusst wie: Ausführen einer Abfrage, die einen primitiven Typ zurückgibt (Entity Framework)
Gewusst wie: Ausführen einer parametrisierten Abfrage (Entity Framework)
Konzepte
Abfrage-Generator-Methoden (Entity Framework)
Weitere Ressourcen
Abfragen eines Entity Data Model (Entity Framework-Aufgaben)