Примеры синтаксиса запросов на основе методов: группирование (LINQ to Entities)
Приведенные в этом разделе примеры показывают использование метода GroupBy для выполнения запросов к модели AdventureWorks Sales с использованием синтаксиса запросов на основе методов. Модель AdventureWorks Sales, которая используется в этих примерах, построена на основе таблиц Contact, Address, Product, SalesOrderHeader и SalesOrderDetail в образце базы данных AdventureWorks.
В примерах, приведенных в этом разделе, используются следующие инструкции using/Imports.
Option Explicit On
Option Strict On
Imports L2EExamplesVB.AdventureWorksModel
Imports System.Data.Objects
Imports System.Globalization
using System;
using System.Data;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Objects;
using AdventureWorksModel;
using System.Globalization;
Дополнительные сведения см. в разделе Как создать проект LINQ to Entities в среде Visual Studio.
Пример
В следующем примере метод GroupBy возвращает объекты Address, сгруппированные по почтовому индексу. Результаты проецируются на анонимный тип.
Using AWEntities As New AdventureWorksEntities
Dim query = AWEntities.Address _
.GroupBy(Function(Address) Address.PostalCode) _
.Select(Function(Address) Address)
For Each addressGroup As IGrouping(Of String, Address) In query
Console.WriteLine("Postal Code: {0}", addressGroup.Key)
For Each address As Address In addressGroup
Console.WriteLine(" " + address.AddressLine1 + address.AddressLine2)
Next
Next
End Using
using (AdventureWorksEntities AWEntities = new AdventureWorksEntities())
{
var query = AWEntities.Address
.GroupBy( address => address.PostalCode)
.Select( address => address);
foreach (IGrouping<string, Address> addressGroup in query)
{
Console.WriteLine("Postal Code: {0}", addressGroup.Key);
foreach (Address address in addressGroup)
{
Console.WriteLine("\t" + address.AddressLine1 +
address.AddressLine2);
}
}
}
Пример
В следующем примере метод GroupBy возвращает объекты Contact, сгруппированные по первой букве фамилии контактного лица. Кроме того, результаты сортируются по первой букве фамилии и проецируются на анонимный тип.
Using AWEntities As New AdventureWorksEntities
Dim query = AWEntities.Contact _
.GroupBy(Function(c) c.LastName.Substring(0, 1)) _
.OrderBy(Function(c) c.Key) _
.Select(Function(c) c)
For Each group As IGrouping(Of String, Contact) In query
Console.WriteLine("Last names that start with the letter '{0}':", group.Key)
For Each contact As Contact In group
Console.WriteLine(contact.LastName)
Next
Next
End Using
using (AdventureWorksEntities AWEntities = new AdventureWorksEntities())
{
var query = AWEntities.Contact
.GroupBy(c => c.LastName.Substring(0,1))
.OrderBy(c => c.Key)
.Select(c => c);
foreach (IGrouping<string, Contact> group in query)
{
Console.WriteLine("Last names that start with the letter '{0}':",
group.Key);
foreach (Contact contact in group)
{
Console.WriteLine(contact.LastName);
}
}
}
Пример
В следующем примере метод GroupBy возвращает объекты SalesOrderHeader, сгруппированные по идентификатору клиента. Кроме того, возвращается число продаж для каждого клиента.
Using AWEntities As New AdventureWorksEntities
Dim query = AWEntities.SalesOrderHeader _
.GroupBy(Function(order) order.CustomerID)
' Iterate over each IGrouping
For Each group In query
Console.WriteLine("Customer ID: {0}", group.Key)
Console.WriteLine("Order Count: {0}", group.Count)
For Each sale In group
Console.WriteLine(" Sale ID: {0}", sale.SalesOrderID)
Next
Console.WriteLine("")
Next
End Using
using (AdventureWorksEntities AWEntities = new AdventureWorksEntities())
{
var query = AWEntities.SalesOrderHeader
.GroupBy(order => order.CustomerID);
foreach (IGrouping<int, SalesOrderHeader> group in query)
{
Console.WriteLine("Customer ID: {0}", group.Key);
Console.WriteLine("Order count: {0}", group.Count());
foreach (SalesOrderHeader sale in group)
{
Console.WriteLine(" Sale ID: {0}", sale.SalesOrderID);
}
Console.WriteLine("");
}
}
См. также
Основные понятия
Примеры синтаксиса запросов на базе методов (LINQ to Entities)