Queryable.Sum Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Вычисляет сумму последовательности числовых значений.
Перегрузки
| Имя | Описание |
|---|---|
| Sum(IQueryable<Single>) |
Вычисляет сумму последовательности значений Single . |
| Sum(IQueryable<Nullable<Single>>) |
Вычисляет сумму последовательности значений, допускающих Single значение NULL. |
| Sum(IQueryable<Nullable<Int64>>) |
Вычисляет сумму последовательности значений, допускающих Int64 значение NULL. |
| Sum(IQueryable<Nullable<Int32>>) |
Вычисляет сумму последовательности значений, допускающих Int32 значение NULL. |
| Sum(IQueryable<Nullable<Double>>) |
Вычисляет сумму последовательности значений, допускающих Double значение NULL. |
| Sum(IQueryable<Nullable<Decimal>>) |
Вычисляет сумму последовательности значений, допускающих Decimal значение NULL. |
| Sum(IQueryable<Int64>) |
Вычисляет сумму последовательности значений Int64 . |
| Sum(IQueryable<Int32>) |
Вычисляет сумму последовательности значений Int32 . |
| Sum(IQueryable<Double>) |
Вычисляет сумму последовательности значений Double . |
| Sum(IQueryable<Decimal>) |
Вычисляет сумму последовательности значений Decimal . |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) |
Вычисляет сумму последовательности значений Single , полученных путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) |
Вычисляет сумму последовательности значений, допускающих значение NULL Single , полученное путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) |
Вычисляет сумму последовательности значений, допускающих значение NULL Int64 , полученное путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) |
Вычисляет сумму последовательности значений, допускающих значение NULL Int32 , полученное путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) |
Вычисляет сумму последовательности значений, допускающих значение NULL Double , полученное путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) |
Вычисляет сумму последовательности значений, допускающих значение NULL Decimal , полученное путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) |
Вычисляет сумму последовательности значений Int64 , полученных путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) |
Вычисляет сумму последовательности значений Int32 , полученных путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) |
Вычисляет сумму последовательности значений Double , полученных путем вызова функции проекции для каждого элемента входной последовательности. |
| Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) |
Вычисляет сумму последовательности значений Decimal , полученных путем вызова функции проекции для каждого элемента входной последовательности. |
Sum(IQueryable<Single>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Single .
public:
[System::Runtime::CompilerServices::Extension]
static float Sum(System::Linq::IQueryable<float> ^ source);
public static float Sum(this System.Linq.IQueryable<float> source);
static member Sum : System.Linq.IQueryable<single> -> single
<Extension()>
Public Function Sum (source As IQueryable(Of Single)) As Single
Параметры
- source
- IQueryable<Single>
Последовательность значений Single для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Примеры
В следующем примере кода показано, как использовать Sum(IQueryable<Single>) для суммирования значений последовательности.
List<float> numbers = new List<float> { 43.68F, 1.25F, 583.7F, 6.5F };
float sum = numbers.AsQueryable().Sum();
Console.WriteLine("The sum of the numbers is {0}.", sum);
/*
This code produces the following output:
The sum of the numbers is 635.13.
*/
Dim numbers As New List(Of Single)(New Single() {43.68F, 1.25F, 583.7F, 6.5F})
Dim sum As Single = numbers.AsQueryable().Sum()
MsgBox("The sum of the numbers is " & sum)
' This code produces the following output:
' The sum of the numbers is 635.13.
Комментарии
Метод Sum(IQueryable<Single>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Single>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Single>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Nullable<Single>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих Single значение NULL.
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<float> Sum(System::Linq::IQueryable<Nullable<float>> ^ source);
public static float? Sum(this System.Linq.IQueryable<float?> source);
static member Sum : System.Linq.IQueryable<Nullable<single>> -> Nullable<single>
<Extension()>
Public Function Sum (source As IQueryable(Of Nullable(Of Single))) As Nullable(Of Single)
Параметры
- source
- IQueryable<Nullable<Single>>
Последовательность значений, допускающих Single значение NULL, для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Примеры
В следующем примере кода показано, как использовать Sum(IQueryable<Nullable<Single>>) для суммирования значений последовательности.
float?[] points = { null, 0, 92.83F, null, 100.0F, 37.46F, 81.1F };
float? sum = points.AsQueryable().Sum();
Console.WriteLine("Total points earned: {0}", sum);
/*
This code produces the following output:
Total points earned: 311.39
*/
Dim points As Nullable(Of Single)() = {Nothing, 0, 92.83F, Nothing, 100.0F, 37.46F, 81.1F}
Dim sum As Nullable(Of Single) = points.AsQueryable().Sum()
MsgBox("Total points earned: " & sum)
'This code produces the following output:
'Total points earned: 311.39
Комментарии
Метод Sum(IQueryable<Nullable<Single>>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Nullable<Single>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Single>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Nullable<Int64>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих Int64 значение NULL.
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<long> Sum(System::Linq::IQueryable<Nullable<long>> ^ source);
public static long? Sum(this System.Linq.IQueryable<long?> source);
static member Sum : System.Linq.IQueryable<Nullable<int64>> -> Nullable<int64>
<Extension()>
Public Function Sum (source As IQueryable(Of Nullable(Of Long))) As Nullable(Of Long)
Параметры
- source
- IQueryable<Nullable<Int64>>
Последовательность значений, допускающих Int64 значение NULL, для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Сумма больше, чем Int64.MaxValue.
Комментарии
Метод Sum(IQueryable<Nullable<Int64>>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Nullable<Int64>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Int64>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Nullable<Int32>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих Int32 значение NULL.
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<int> Sum(System::Linq::IQueryable<Nullable<int>> ^ source);
public static int? Sum(this System.Linq.IQueryable<int?> source);
static member Sum : System.Linq.IQueryable<Nullable<int>> -> Nullable<int>
<Extension()>
Public Function Sum (source As IQueryable(Of Nullable(Of Integer))) As Nullable(Of Integer)
Параметры
- source
- IQueryable<Nullable<Int32>>
Последовательность значений, допускающих Int32 значение NULL, для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Сумма больше, чем Int32.MaxValue.
Комментарии
Метод Sum(IQueryable<Nullable<Int32>>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Nullable<Int32>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Int32>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Nullable<Double>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих Double значение NULL.
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Sum(System::Linq::IQueryable<Nullable<double>> ^ source);
public static double? Sum(this System.Linq.IQueryable<double?> source);
static member Sum : System.Linq.IQueryable<Nullable<double>> -> Nullable<double>
<Extension()>
Public Function Sum (source As IQueryable(Of Nullable(Of Double))) As Nullable(Of Double)
Параметры
- source
- IQueryable<Nullable<Double>>
Последовательность значений, допускающих Double значение NULL, для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Комментарии
Метод Sum(IQueryable<Nullable<Double>>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Nullable<Double>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Double>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Nullable<Decimal>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих Decimal значение NULL.
public:
[System::Runtime::CompilerServices::Extension]
static Nullable<System::Decimal> Sum(System::Linq::IQueryable<Nullable<System::Decimal>> ^ source);
public static decimal? Sum(this System.Linq.IQueryable<decimal?> source);
static member Sum : System.Linq.IQueryable<Nullable<decimal>> -> Nullable<decimal>
<Extension()>
Public Function Sum (source As IQueryable(Of Nullable(Of Decimal))) As Nullable(Of Decimal)
Параметры
- source
- IQueryable<Nullable<Decimal>>
Последовательность значений, допускающих Decimal значение NULL, для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Сумма превышает десятичное значение MaxValue.
Комментарии
Метод Sum(IQueryable<Nullable<Decimal>>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Nullable<Decimal>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Decimal>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Int64>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Int64 .
public:
[System::Runtime::CompilerServices::Extension]
static long Sum(System::Linq::IQueryable<long> ^ source);
public static long Sum(this System.Linq.IQueryable<long> source);
static member Sum : System.Linq.IQueryable<int64> -> int64
<Extension()>
Public Function Sum (source As IQueryable(Of Long)) As Long
Параметры
- source
- IQueryable<Int64>
Последовательность значений Int64 для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Сумма больше, чем Int64.MaxValue.
Комментарии
Метод Sum(IQueryable<Int64>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Int64>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Int64>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Int32>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Int32 .
public:
[System::Runtime::CompilerServices::Extension]
static int Sum(System::Linq::IQueryable<int> ^ source);
public static int Sum(this System.Linq.IQueryable<int> source);
static member Sum : System.Linq.IQueryable<int> -> int
<Extension()>
Public Function Sum (source As IQueryable(Of Integer)) As Integer
Параметры
- source
- IQueryable<Int32>
Последовательность значений Int32 для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Сумма больше, чем Int32.MaxValue.
Комментарии
Метод Sum(IQueryable<Int32>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Int32>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Int32>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Double>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Double .
public:
[System::Runtime::CompilerServices::Extension]
static double Sum(System::Linq::IQueryable<double> ^ source);
public static double Sum(this System.Linq.IQueryable<double> source);
static member Sum : System.Linq.IQueryable<double> -> double
<Extension()>
Public Function Sum (source As IQueryable(Of Double)) As Double
Параметры
- source
- IQueryable<Double>
Последовательность значений Double для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Комментарии
Метод Sum(IQueryable<Double>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Double>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Double>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum(IQueryable<Decimal>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Decimal .
public:
[System::Runtime::CompilerServices::Extension]
static System::Decimal Sum(System::Linq::IQueryable<System::Decimal> ^ source);
public static decimal Sum(this System.Linq.IQueryable<decimal> source);
static member Sum : System.Linq.IQueryable<decimal> -> decimal
<Extension()>
Public Function Sum (source As IQueryable(Of Decimal)) As Decimal
Параметры
- source
- IQueryable<Decimal>
Последовательность значений Decimal для вычисления суммы.
Возвращаемое значение
Сумма значений в последовательности.
Исключения
source равно null.
Сумма превышает десятичное значение MaxValue.
Комментарии
Метод Sum(IQueryable<Decimal>) создает объект MethodCallExpression , представляющий Sum(IQueryable<Decimal>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Decimal>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Single , полученных путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static float Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, float> ^> ^ selector);
public static float Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static float Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, single>> -> single
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, single>> -> single
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Single))) As Single
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Single>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих значение NULL Single , полученное путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<float> Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<float>> ^> ^ selector);
public static float? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float?>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static float? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float?>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<single>>> -> Nullable<single>
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<single>>> -> Nullable<single>
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Single)))) As Nullable(Of Single)
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Nullable<Single>>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих значение NULL Int64 , полученное путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<long> Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<long>> ^> ^ selector);
public static long? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long?>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static long? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long?>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<int64>>> -> Nullable<int64>
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<int64>>> -> Nullable<int64>
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Long)))) As Nullable(Of Long)
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Nullable<Int64>>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Сумма больше, чем Int64.MaxValue.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих значение NULL Int32 , полученное путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<int> Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<int>> ^> ^ selector);
public static int? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int?>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static int? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int?>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<int>>> -> Nullable<int>
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<int>>> -> Nullable<int>
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Integer)))) As Nullable(Of Integer)
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Nullable<Int32>>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Сумма больше, чем Int32.MaxValue.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих значение NULL Double , полученное путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<double> Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<double>> ^> ^ selector);
public static double? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double?>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static double? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double?>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<double>>> -> Nullable<double>
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<double>>> -> Nullable<double>
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Double)))) As Nullable(Of Double)
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Nullable<Double>>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений, допускающих значение NULL Decimal , полученное путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static Nullable<System::Decimal> Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, Nullable<System::Decimal>> ^> ^ selector);
public static decimal? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal?>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static decimal? Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal?>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<decimal>>> -> Nullable<decimal>
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, Nullable<decimal>>> -> Nullable<decimal>
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Nullable(Of Decimal)))) As Nullable(Of Decimal)
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Nullable<Decimal>>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Сумма превышает десятичное значение MaxValue.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Int64 , полученных путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static long Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, long> ^> ^ selector);
public static long Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static long Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, int64>> -> int64
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, int64>> -> int64
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Long))) As Long
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Int64>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Сумма больше, чем Int64.MaxValue.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Int32 , полученных путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static int Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, int> ^> ^ selector);
public static int Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static int Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, int>> -> int
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, int>> -> int
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Integer))) As Integer
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Int32>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Сумма больше, чем Int32.MaxValue.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Double , полученных путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static double Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, double> ^> ^ selector);
public static double Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static double Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, double>> -> double
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, double>> -> double
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Double))) As Double
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Double>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.
Применяется к
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>)
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
- Исходный код:
- Queryable.cs
Вычисляет сумму последовательности значений Decimal , полученных путем вызова функции проекции для каждого элемента входной последовательности.
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static System::Decimal Sum(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, System::Decimal> ^> ^ selector);
public static decimal Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal>> selector);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")]
public static decimal Sum<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal>> selector);
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, decimal>> -> decimal
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("Enumerating collections as IQueryable can require creating new generic types or methods, which requires creating code at runtime. This may not work when AOT compiling.")>]
static member Sum : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, decimal>> -> decimal
<Extension()>
Public Function Sum(Of TSource) (source As IQueryable(Of TSource), selector As Expression(Of Func(Of TSource, Decimal))) As Decimal
Параметры типа
- TSource
Тип элементов source.
Параметры
- source
- IQueryable<TSource>
Последовательность значений типа TSource.
- selector
- Expression<Func<TSource,Decimal>>
Функция проекции, применяемая к каждому элементу.
Возвращаемое значение
Сумма проецируемых значений.
- Атрибуты
Исключения
source или selector есть null.
Сумма превышает десятичное значение MaxValue.
Примеры
В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.
Замечание
В этом примере кода используется перегрузка метода, отличающегося от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример перегрузки, описанной в этой статье, измените текст selector функции.
class Package
{
public string Company { get; set; }
public double Weight { get; set; }
}
public static void SumEx3()
{
List<Package> packages =
new List<Package>
{ new Package { Company = "Coho Vineyard", Weight = 25.2 },
new Package { Company = "Lucerne Publishing", Weight = 18.7 },
new Package { Company = "Wingtip Toys", Weight = 6.0 },
new Package { Company = "Adventure Works", Weight = 33.8 } };
// Calculate the sum of all package weights.
double totalWeight = packages.AsQueryable().Sum(pkg => pkg.Weight);
Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}
/*
This code produces the following output:
The total weight of the packages is: 83.7
*/
Structure Package
Public Company As String
Public Weight As Double
End Structure
Shared Sub SumEx3()
Dim packages As New List(Of Package)(New Package() { _
New Package With {.Company = "Coho Vineyard", .Weight = 25.2}, _
New Package With {.Company = "Lucerne Publishing", .Weight = 18.7}, _
New Package With {.Company = "Wingtip Toys", .Weight = 6.0}, _
New Package With {.Company = "Adventure Works", .Weight = 33.8}})
' Calculate the sum of all package weights.
Dim totalWeight As Double = packages.AsQueryable().Sum(Function(pkg) pkg.Weight)
MsgBox("The total weight of the packages is: " & totalWeight)
End Sub
'This code produces the following output:
'The total weight of the packages is: 83.7
Комментарии
Этот метод имеет по крайней мере один параметр типа, аргумент типа Expression<TDelegate> которого является одним из Func<T,TResult> типов. Для этих параметров можно передать лямбда-выражение и скомпилировать его в Expression<TDelegate>лямбда-выражение.
Метод Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) создает объект MethodCallExpression , представляющий Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) себя как созданный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) метод IQueryProvider метода, представленного Provider свойством source параметра.
Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывается selector на каждом элементе source и возвращает сумму результирующего значения.