Udostępnij za pośrednictwem


Zwracanie średniej wartości z sekwencji numerycznej

Operator Average oblicza średnią sekwencji wartości liczbowych.

Uwaga

Translacja Average LINQ to SQL wartości całkowitych jest obliczana jako liczba całkowita, a nie jako podwójna.

Przykład 1

Poniższy przykład zwraca średnią Freight wartości w Orders tabeli.

Wyniki z przykładowej bazy danych Northwind to 78.2442.

System.Nullable<Decimal> averageFreight =
    (from ord in db.Orders
    select ord.Freight)
    .Average();

Console.WriteLine(averageFreight);
Dim averageFreight = Aggregate ord In db.Orders _
                     Into Average(ord.Freight)

Console.WriteLine(averageFreight)

Przykład 2

Poniższy przykład zwraca średnią ceny jednostkowej wszystkich Products w Products tabeli.

Wyniki z przykładowej bazy danych Northwind to 28.8663.

System.Nullable<Decimal> averageUnitPrice =
    (from prod in db.Products
    select prod.UnitPrice)
    .Average();

Console.WriteLine(averageUnitPrice);
Dim averageUnitPrice = Aggregate prod In db.Products _
                       Into Average(prod.UnitPrice)

Console.WriteLine(averageUnitPrice)

Przykład 3

W poniższym przykładzie Average użyto operatora do znalezienia tych Products , których cena jednostkowa jest wyższa niż średnia cena jednostkowa kategorii, do której należy. W przykładzie zostaną wyświetlone wyniki w grupach.

Należy pamiętać, że w tym przykładzie jest wymagane użycie słowa kluczowego var w języku C#, ponieważ zwracany typ jest anonimowy.

var priceQuery =
    from prod in db.Products
    group prod by prod.CategoryID into grouping
    select new
    {
        grouping.Key,
        ExpensiveProducts =
            from prod2 in grouping
            where prod2.UnitPrice > grouping.Average(prod3 =>
                prod3.UnitPrice)
        select prod2
    };

foreach (var grp in priceQuery)
{
    Console.WriteLine(grp.Key);
    foreach (var listing in grp.ExpensiveProducts)
    {
        Console.WriteLine(listing.ProductName);
    }
}
Dim priceQuery = From prod In db.Products() _
                 Group prod By prod.CategoryID Into grouping = Group _
                 Select CategoryID, _
                 ExpensiveProducts = _
                     (From prod2 In grouping _
                      Where prod2.UnitPrice > _
                     grouping.Average(Function(prod3) _
                     prod3.UnitPrice) _
                      Select prod2)

For Each grp In priceQuery
    Console.WriteLine(grp.CategoryID)
    For Each listing In grp.ExpensiveProducts
        Console.WriteLine(listing.ProductName)
    Next
Next

Jeśli uruchomisz to zapytanie względem przykładowej bazy danych Northwind, wyniki powinny wyglądać podobnie do następujących:

1

Côte de Blaye

Ipoh Coffee

2

Grandma's Boysenberry Spread

Northwoods Cranberry Sauce

Sirop d'érable

Vegie-spread

3

Sir Rodney's Marmalade

Gumbär Gummibärchen

Schoggi Schokolade

Tarte au sucre

4

Queso Manchego La Pastora

Mascarpone Fabioli

Raclette Courdavault

Camembert Pierrot

Gudbrandsdalsost

Mozzarella di Giovanni

5

Gustaf's Knäckebröd

Gnocchi di nonna Alice

Wimmers gute Semmelknödel

6

Mishi Kobe Niku

Thüringer Rostbratwurst

7

Rössle Sauerkraut

Manjimup Dried Apples

8

Ikura

Carnarvon Tigers

Nord-Ost Matjeshering

Gravad lax

Zobacz też