집계 절(Visual Basic)
하나 이상의 집계 함수를 컬렉션에 적용합니다.
구문
Aggregate element [As type] In collection _
[, element2 [As type2] In collection2, [...]]
[ clause ]
Into expressionList
부분
용어 | 정의 |
---|---|
element |
필수입니다. 컬렉션의 요소를 반복하는 데 사용되는 변수입니다. |
type |
선택 사항. element 의 형식입니다. 형식을 지정하지 않으면 element 의 형식이 collection 에서 유추됩니다. |
collection |
필수입니다. 작동할 컬렉션을 참조합니다. |
clause |
선택 사항. Where 절과 같은 하나 이상의 쿼리 절을 사용하여 집계 절 또는 절을 적용하도록 쿼리 결과를 구체화합니다. |
expressionList |
필수입니다. 컬렉션에 적용할 집계 함수를 식별하는 하나 이상의 쉼표로 구분된 식입니다. 집계 함수에 별칭을 적용하여 쿼리 결과의 멤버 이름을 지정할 수 있습니다. 별칭이 제공되지 않으면 집계 함수의 이름이 사용됩니다. 예제는 이 항목의 뒷부분에 있는 집계 함수에 대한 섹션을 참조하세요. |
설명
Aggregate
절을 사용하여 쿼리에 집계 함수를 포함할 수 있습니다. 집계 함수는 값 집합에 대한 검사 및 계산을 수행하고 단일 값을 반환합니다. 쿼리 결과 형식의 멤버를 사용하여 계산된 값에 액세스할 수 있습니다. 사용할 수 있는 표준 집계 함수는 All
, Any
, Average
, Count
, LongCount
, Max
, Min
, Sum
함수입니다. 이러한 함수는 SQL의 집계에 익숙한 개발자에게 친숙합니다. 이 토픽의 다음 섹션에 설명되어 있습니다.
집계 함수의 결과는 쿼리 결과 형식의 필드로 쿼리 결과에 포함됩니다. 집계 함수 결과에 대한 별칭을 제공하여 집계 값을 보유할 쿼리 결과 형식의 멤버 이름을 지정할 수 있습니다. 별칭이 제공되지 않으면 집계 함수의 이름이 사용됩니다.
Aggregate
절은 쿼리를 시작하거나 쿼리에 추가 절로 포함할 수 있습니다. Aggregate
절이 쿼리를 시작하는 경우 결과는 Into
절에 지정된 집계 함수의 결과인 단일 값입니다. Into
절에 둘 이상의 집계 함수가 지정된 경우 쿼리는 별도의 속성이 있는 단일 형식을 반환하여 Into
절에 있는 각 집계 함수의 결과를 참조합니다. Aggregate
절이 쿼리에 추가 절로 포함된 경우 쿼리 컬렉션에 반환된 형식에는 Into
절에 있는 각 집계 함수의 결과를 참조하는 별도의 속성이 있습니다.
집계 함수
다음은 Aggregate
절과 함께 사용할 수 있는 표준 집계 함수입니다.
모두
컬렉션의 모든 요소가 지정된 조건을 충족하면 true
를 반환하고, 그러지 않으면 false
를 반환합니다. 다음은 이에 대한 예입니다.
Dim customerList1 = Aggregate order In orders
Into AllOrdersOver100 = All(order.Total >= 100)
모두
컬렉션의 요소가 지정된 조건을 충족하면 true
를 반환하고, 그러지 않으면 false
를 반환합니다. 다음은 이에 대한 예입니다.
Dim customerList2 = From cust In customers
Aggregate order In cust.Orders
Into AnyOrderOver500 = Any(order.Total >= 500)
평균
컬렉션에 있는 모든 요소의 평균을 계산하거나 컬렉션의 모든 요소에 대해 제공된 식을 계산합니다. 다음은 이에 대한 예입니다.
Dim customerOrderAverage = Aggregate order In orders
Into Average(order.Total)
Count
컨테이너의 요소 개수를 셉니다. 조건을 충족하는 컬렉션의 요소 개수만 계산하는 선택적 Boolean
식을 제공할 수 있습니다. 다음은 이에 대한 예입니다.
Dim customerOrderAfter1996 = From cust In customers
Aggregate order In cust.Orders
Into Count(order.OrderDate > #12/31/1996#)
그룹
Group By
또는 Group Join
절의 결과로 그룹화된 쿼리 결과를 참조합니다. Group
함수는 Group By
또는 Group Join
절의 Into
절에서만 유효합니다. 자세한 내용 및 예제는 Group By 절 및 Group Join 절을 참조하세요.
LongCount
컨테이너의 요소 개수를 셉니다. 조건을 충족하는 컬렉션의 요소 개수만 계산하는 선택적 Boolean
식을 제공할 수 있습니다. 결과를 Long
으로 반환합니다. 예를 들어 Count
집계 함수를 참조하세요.
최대
컬렉션의 최댓값을 계산하거나 컬렉션의 모든 요소에 대해 제공된 식을 계산합니다. 다음은 이에 대한 예입니다.
Dim customerMaxOrder = Aggregate order In orders
Into MaxOrder = Max(order.Total)
Min
컬렉션에서 최솟값을 계산하거나 컬렉션의 모든 요소에 대해 제공된 식을 계산합니다. 다음은 이에 대한 예입니다.
Dim customerMinOrder = From cust In customers
Aggregate order In cust.Orders
Into MinOrder = Min(order.Total)
Sum
컬렉션에 있는 모든 요소의 합계를 계산하거나 컬렉션의 모든 요소에 대해 제공된 식을 계산합니다. 다음은 이에 대한 예입니다.
Dim customerTotals = From cust In customers
Aggregate order In cust.Orders
Into Sum(order.Total)
예시
다음 예제에서는 Aggregate
절을 사용하여 쿼리 결과에 집계 함수를 적용하는 방법을 보여 줍니다.
Public Sub AggregateSample()
Dim customers = GetCustomerList()
Dim customerOrderTotal =
From cust In customers
Aggregate order In cust.Orders
Into Sum(order.Total), MaxOrder = Max(order.Total),
MinOrder = Min(order.Total), Avg = Average(order.Total)
For Each customer In customerOrderTotal
Console.WriteLine(customer.cust.CompanyName & vbCrLf &
vbTab & "Sum = " & customer.Sum & vbCrLf &
vbTab & "Min = " & customer.MinOrder & vbCrLf &
vbTab & "Max = " & customer.MaxOrder & vbCrLf &
vbTab & "Avg = " & customer.Avg.ToString("#.##"))
Next
End Sub
사용자 정의 집계 함수 만들기
IEnumerable<T> 형식에 확장 메서드를 추가하여 쿼리 식에 사용자 지정 집계 함수를 포함할 수 있습니다. 그런 다음, 사용자 지정 메서드는 집계 함수를 참조한 열거 가능한 컬렉션에서 계산 또는 작업을 수행할 수 있습니다. 확장 메서드에 대한 자세한 내용은 확장 메서드를 참조하세요.
예를 들어 다음 예제에서는 숫자 컬렉션의 중앙값을 계산하는 사용자 지정 집계 함수를 보여 줍니다. Median
확장 메서드에는 두 개의 오버로드가 있습니다. 첫 번째 오버로드는 형식 IEnumerable(Of Double)
의 컬렉션을 입력으로 허용합니다. 형식 Double
의 쿼리 필드에 대해 Median
집계 함수가 호출되면 이 메서드가 호출됩니다. Median
메서드의 두 번째 오버로드는 제네릭 형식을 전달할 수 있습니다. Median
메서드의 제네릭 오버로드는 Func(Of T, Double)
람다 식을 참조하는 두 번째 매개 변수를 사용하여 컬렉션에서 형식의 값을 해당 형식값 Double
으로 프로젝션합니다. 그런 다음, Median
메서드의 다른 오버로드에 중앙값 계산을 위임합니다. 람다 식에 대한 자세한 내용은 람다 식을 참조하세요.
Imports System.Runtime.CompilerServices
Module UserDefinedAggregates
' Calculate the median value for a collection of type Double.
<Extension()>
Function Median(ByVal values As IEnumerable(Of Double)) As Double
If values.Count = 0 Then
Throw New InvalidOperationException("Cannot compute median for an empty set.")
End If
Dim sortedList = From number In values
Order By number
Dim medianValue As Double
Dim itemIndex = CInt(Int(sortedList.Count / 2))
If sortedList.Count Mod 2 = 0 Then
' Even number of items in list.
medianValue = ((sortedList(itemIndex) + sortedList(itemIndex - 1)) / 2)
Else
' Odd number of items in list.
medianValue = sortedList(itemIndex)
End If
Return medianValue
End Function
' "Cast" the collection of generic items as type Double and call the
' Median() method to calculate the median value.
<Extension()>
Function Median(Of T)(ByVal values As IEnumerable(Of T),
ByVal selector As Func(Of T, Double)) As Double
Return (From element In values Select selector(element)).Median()
End Function
End Module
다음 예제에서는 형식 Integer
컬렉션 및 형식 Double
컬렉션에서 Median
집계 함수를 호출하는 샘플 쿼리를 보여 줍니다. 형식 Double
컬렉션에서 Median
집계 함수를 호출하는 쿼리는 형식 Double
컬렉션을 입력으로 수락하는 Median
메서드의 오버로드를 호출합니다. 형식 Integer
컬렉션에서 Median
집계 함수를 호출하는 쿼리는 Median
메서드의 제네릭 오버로드를 호출합니다.
Module Module1
Sub Main()
Dim numbers1 = {1, 2, 3, 4, 5}
Dim query1 = Aggregate num In numbers1 Into Median(num)
Console.WriteLine("Median = " & query1)
Dim numbers2 = {1.9, 2, 8, 4, 5.7, 6, 7.2, 0}
Dim query2 = Aggregate num In numbers2 Into Median()
Console.WriteLine("Median = " & query2)
End Sub
End Module
참고 항목
.NET