Condividi tramite


Procedura: restituire il valore medio da una sequenza numerica (LINQ to SQL)

L'operatore Average calcola la media di una sequenza di valori numerici.

NotaNota

La conversione LINQ to SQL di Average di valori integer viene calcolata come un valore integer, non come un valore double.

Esempio

Nell'esempio seguente viene restituita la media dei valori Freight nella tabella Orders.

Il risultato restituito dal database Northwind di esempio sarà 78.2442.

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

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

Console.WriteLine(averageFreight);

Nell'esempio seguente viene restituito il prezzo unitario medio di tutti i valori Products nella tabella Products.

Il risultato restituito dal database Northwind di esempio sarà 28.8663.

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

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

Console.WriteLine(averageUnitPrice);

Nell'esempio seguente viene utilizzato l'operatore Average per trovare i valori Products il cui prezzo unitario è maggiore del prezzo unitario medio della categoria a cui appartengono tali prodotti. Nell'esempio i risultati vengono visualizzati in gruppi.

Notare che in questo esempio è richiesto l'utilizzo della parola chiave var in C#, perché il tipo restituito è anonimo.

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
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);
    }
}

Se si esegue questa query sul database di esempio Northwind, i risultati saranno simili ai seguenti:

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

Vedere anche

Altre risorse

Query di aggregazione (LINQ to SQL)