Restituire il valore medio da una sequenza numerica
L'operatore Average calcola la media di una sequenza di valori numerici.
Nota
La conversione LINQ to SQL di Average
di valori integer viene calcolata come un valore integer, non come un valore double.
Esempio 1
Nell'esempio seguente viene restituita la media dei valori Freight
nella tabella Orders
.
Il risultato restituito dal database Northwind di esempio sarà 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)
Esempio 2
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
.
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)
Esempio 3
Nell'esempio seguente viene usato 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'uso della parola chiave var
in C#, perché il tipo restituito è anonimo.
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
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