Share via


Gewusst wie: Filtern von Daten (Entity Framework)

In diesem Thema wird gezeigt, wie Abfrageergebnisse gefiltert werden. Im Beispiel wird eine Auflistung von SalesOrderHeader-Objekten zurückgegeben, die Onlinebestellungen über mehr als 2.500 Dollar darstellen. Dasselbe Beispiel wird unter Verwendung 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 basieren auf dem AdventureWorks Sales-Modell. Um den Code in diesem Beispiel auszuführen, müssen Sie dem Projekt bereits das AdventureWorks Sales-Modell hinzugefügt und das Projekt zur Verwendung von Entity Framework konfiguriert haben. Führen Sie dazu die Verfahren unter Gewusst wie: Manuelles Konfigurieren eines Entity Framework-Projekts und Gewusst wie: Manuelles Definieren eines Entity Data Model (Entity Framework) durch. 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

Es folgt das LINQ-to-Entities-Beispiel:

Using context As AdventureWorksEntities = _
New AdventureWorksEntities()

    ' Specify the order amount.
    Dim orderCost As Integer = 2500

    Try
        ' Define a LINQ query that returns only online orders
        ' more than the specified amount.
        Dim onlineOrders = _
        From order As SalesOrderHeader In context.SalesOrderHeader() _
            Where order.OnlineOrderFlag = True And _
            order.TotalDue > orderCost _
            Select order

        ' Print order information.
        For Each onlineOrder In onlineOrders

            Console.WriteLine("Order ID:{0}Order date: " _
                + "{1}:d Order number: {2}", _
                onlineOrder.SalesOrderID, _
                onlineOrder.OrderDate, _
                onlineOrder.SalesOrderNumber)
        Next
    Catch ex As EntitySqlException
        Console.WriteLine(ex.ToString())
    End Try
End Using
using (AdventureWorksEntities context = new AdventureWorksEntities())
{
    // Specify the order amount.
    int orderCost = 2500;

    try
    {
        // Define a LINQ query that returns only online orders
        // more than the specified amount.
        var onlineOrders =
            from order in context.SalesOrderHeader
            where order.OnlineOrderFlag == true &&
            order.TotalDue > orderCost
            select order;

        // Print order information.
        foreach (var onlineOrder in onlineOrders)
        {
            Console.WriteLine("Order ID: {0} Order date: "
                + "{1:d} Order number: {2}",
                onlineOrder.SalesOrderID,
                onlineOrder.OrderDate,
                onlineOrder.SalesOrderNumber);
        }
    }
    catch (EntitySqlException ex)
    {
        Console.WriteLine(ex.ToString());
    }
}

Es folgt das Entity SQL-Beispiel:

Using context As AdventureWorksEntities = _
New AdventureWorksEntities()

    ' Specify the order amount.
    Dim orderCost As Integer = 2500

    ' Specify the Entity SQL query that returns only online orders
    ' more than the specified amount.
    Dim queryString As String = "SELECT VALUE o FROM SalesOrderHeader AS o " _
    + "WHERE o.OnlineOrderFlag = TRUE AND o.TotalDue > @ordercost"

    Try
        ' Define an ObjectQuery and pass the maxOrderCost parameter.
        Dim onlineOrders As ObjectQuery(Of SalesOrderHeader) = _
            New ObjectQuery(Of SalesOrderHeader)(queryString, context)
        onlineOrders.Parameters.Add( _
            New ObjectParameter("ordercost", orderCost))

        ' Print order information.
        For Each onlineOrder In onlineOrders
            Console.WriteLine("Order ID:{0}Order date: " _
                + "{1}:d Order number: {2}", _
                onlineOrder.SalesOrderID, _
                onlineOrder.OrderDate, _
                onlineOrder.SalesOrderNumber)
        Next
    Catch ex As EntitySqlException
        Console.WriteLine(ex.ToString())
    End Try
End Using
using (AdventureWorksEntities context = new AdventureWorksEntities())
{
    // Specify the order amount.
    decimal orderCost = 2500;

    // Specify the Entity SQL query that returns only online orders
    // more than the specified amount.
    string queryString = @"SELECT VALUE o FROM SalesOrderHeader AS o 
        WHERE o.OnlineOrderFlag = TRUE AND o.TotalDue > @ordercost";

    try
    {
        // Define an ObjectQuery and pass the maxOrderCost parameter.
        ObjectQuery<SalesOrderHeader> onlineOrders =
            new ObjectQuery<SalesOrderHeader>(queryString, context);
        onlineOrders.Parameters.Add(
            new ObjectParameter("ordercost", orderCost));

        // Print order information.
        foreach (var onlineOrder in onlineOrders)
        {
            Console.WriteLine("Order ID: {0} Order date: "
                + "{1:d} Order number: {2}",
                onlineOrder.SalesOrderID,
                onlineOrder.OrderDate,
                onlineOrder.SalesOrderNumber);
        }
    }
    catch (EntitySqlException ex)
    {
        Console.WriteLine(ex.ToString());
    }
}

Im Folgenden wird ein Beispiel für die Abfrage-Generator-Methode dargestellt.

Using context As AdventureWorksEntities = _
New AdventureWorksEntities()

    ' Specify the order amount.
    Dim orderCost As Integer = 2500

    Try

        ' Define an ObjectQuery that returns only online orders 
        ' more than the specified amount.
        Dim onlineOrders As ObjectQuery(Of SalesOrderHeader) = _
        context.SalesOrderHeader.Where("it.OnlineOrderFlag = TRUE") _
            .Where("it.TotalDue > @ordercost", _
            New ObjectParameter("ordercost", orderCost))

        ' Print order information.
        For Each onlineOrder In onlineOrders
            Console.WriteLine("Order ID:{0}Order date: " _
                + "{1}:d Order number: {2}", _
                onlineOrder.SalesOrderID, _
                onlineOrder.OrderDate, _
                onlineOrder.SalesOrderNumber)
        Next
    Catch ex As EntitySqlException
        Console.WriteLine(ex.ToString())
    End Try
End Using
using (AdventureWorksEntities context = new AdventureWorksEntities())
{
    // Specify the order amount.
    int orderCost = 2500;

   try
    {
        // Define an ObjectQuery that returns only online orders 
        // more than the specified amount.
        ObjectQuery<SalesOrderHeader> onlineOrders =
            context.SalesOrderHeader
            .Where("it.OnlineOrderFlag = TRUE AND it.TotalDue > @ordercost",
            new ObjectParameter("ordercost", orderCost));

        // Print order information.
        foreach (var onlineOrder in onlineOrders)
        {
            var items = (from item in context.SalesOrderDetail
                        where item.SalesOrderHeader == onlineOrder
                        select item).Take(3);
             Console.WriteLine("Order ID: {0} Order date: "
                + "{1:d} Order number: {2}",
                onlineOrder.SalesOrderID,
                onlineOrder.OrderDate,
                onlineOrder.SalesOrderNumber);
        }
    }
    catch (EntitySqlException ex)
    {
        Console.WriteLine(ex.ToString());
    }
}

Siehe auch

Weitere Ressourcen

Abfragen eines Entity Data Model (Entity Framework-Aufgaben)