Прочитать на английском

Поделиться через


Queryable.Sum Метод

Определение

Вычисляет сумму последовательности числовых значений.

Перегрузки

Sum(IQueryable<Decimal>)

Вычисляет сумму последовательности значений типа Decimal.

Sum(IQueryable<Double>)

Вычисляет сумму последовательности значений типа Double.

Sum(IQueryable<Int32>)

Вычисляет сумму последовательности значений типа Int32.

Sum(IQueryable<Int64>)

Вычисляет сумму последовательности значений типа Int64.

Sum(IQueryable<Nullable<Decimal>>)

Вычисляет сумму последовательности значений Decimal обнуляемого типа.

Sum(IQueryable<Nullable<Double>>)

Вычисляет сумму последовательности значений Double обнуляемого типа.

Sum(IQueryable<Nullable<Int32>>)

Вычисляет сумму последовательности значений Int32 обнуляемого типа.

Sum(IQueryable<Nullable<Int64>>)

Вычисляет сумму последовательности значений Int64 обнуляемого типа.

Sum(IQueryable<Nullable<Single>>)

Вычисляет сумму последовательности значений Single обнуляемого типа.

Sum(IQueryable<Single>)

Вычисляет сумму последовательности значений типа Single.

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>)

Вычисляет сумму последовательности значений типа Single, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>)

Вычисляет сумму последовательности значений Single обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>)

Вычисляет сумму последовательности значений Int64 обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>)

Вычисляет сумму последовательности значений Double обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>)

Вычисляет сумму последовательности значений Int32 обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>)

Вычисляет сумму последовательности значений типа Int64, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>)

Вычисляет сумму последовательности значений Decimal обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

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<Decimal>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Decimal.

C#
public static decimal Sum (this System.Linq.IQueryable<decimal> source);

Параметры

source
IQueryable<Decimal>

Последовательность значений Decimal, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Сумма больше, чем Decimal.MaxValue.

Комментарии

Метод Sum(IQueryable<Decimal>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Decimal>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Decimal>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Double>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Double.

C#
public static double Sum (this System.Linq.IQueryable<double> source);

Параметры

source
IQueryable<Double>

Последовательность значений Double, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Комментарии

Метод Sum(IQueryable<Double>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Double>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Double>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Int32>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Int32.

C#
public static int Sum (this System.Linq.IQueryable<int> source);

Параметры

source
IQueryable<Int32>

Последовательность значений Int32, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Сумма больше, чем Int32.MaxValue.

Комментарии

Метод Sum(IQueryable<Int32>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Int32>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Int32>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Int64>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Int64.

C#
public static long Sum (this System.Linq.IQueryable<long> source);

Параметры

source
IQueryable<Int64>

Последовательность значений Int64, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Сумма больше, чем Int64.MaxValue.

Комментарии

Метод Sum(IQueryable<Int64>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Int64>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Int64>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Nullable<Decimal>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Decimal обнуляемого типа.

C#
public static decimal? Sum (this System.Linq.IQueryable<decimal?> source);

Параметры

source
IQueryable<Nullable<Decimal>>

Последовательность значений Decimal обнуляемого типа, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Сумма больше, чем Decimal.MaxValue.

Комментарии

Метод Sum(IQueryable<Nullable<Decimal>>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Nullable<Decimal>>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Decimal>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Nullable<Double>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Double обнуляемого типа.

C#
public static double? Sum (this System.Linq.IQueryable<double?> source);

Параметры

source
IQueryable<Nullable<Double>>

Последовательность значений Double обнуляемого типа, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Комментарии

Метод Sum(IQueryable<Nullable<Double>>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Nullable<Double>>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Double>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Nullable<Int32>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Int32 обнуляемого типа.

C#
public static int? Sum (this System.Linq.IQueryable<int?> source);

Параметры

source
IQueryable<Nullable<Int32>>

Последовательность значений Int32 обнуляемого типа, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Сумма больше, чем Int32.MaxValue.

Комментарии

Метод Sum(IQueryable<Nullable<Int32>>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Nullable<Int32>>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Int32>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Nullable<Int64>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Int64 обнуляемого типа.

C#
public static long? Sum (this System.Linq.IQueryable<long?> source);

Параметры

source
IQueryable<Nullable<Int64>>

Последовательность значений Int64 обнуляемого типа, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Сумма больше, чем Int64.MaxValue.

Комментарии

Метод Sum(IQueryable<Nullable<Int64>>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Nullable<Int64>>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Int64>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Nullable<Single>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Single обнуляемого типа.

C#
public static float? Sum (this System.Linq.IQueryable<float?> source);

Параметры

source
IQueryable<Nullable<Single>>

Последовательность значений Single обнуляемого типа, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Примеры

В следующем примере кода показано, как использовать Sum(IQueryable<Nullable<Single>>) для суммирования значений последовательности.

C#
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
*/

Комментарии

Метод Sum(IQueryable<Nullable<Single>>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Nullable<Single>>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Nullable<Single>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum(IQueryable<Single>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Single.

C#
public static float Sum (this System.Linq.IQueryable<float> source);

Параметры

source
IQueryable<Single>

Последовательность значений Single, сумму которых требуется вычислить.

Возвращаемое значение

Сумма последовательности значений.

Исключения

source имеет значение null.

Примеры

В следующем примере кода показано, как использовать Sum(IQueryable<Single>) для суммирования значений последовательности.

C#
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.
*/

Комментарии

Метод Sum(IQueryable<Single>) создает объект , MethodCallExpression представляющий вызов Sum(IQueryable<Single>) как сконструированный универсальный метод. Затем он передает MethodCallExpressionExecute<TResult>(Expression) в метод объекта , представленный IQueryProvider свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum(IQueryable<Single>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он возвращает сумму значений в source.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Single, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static float Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float>> selector);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IQueryable<TSource>

Последовательность значений типа TSource.

selector
Expression<Func<TSource,Single>>

Функция проекции, применяемая к каждому элементу.

Возвращаемое значение

Сумма проецированных значений.

Исключения

Параметр source или selector имеет значение null.

Примеры

В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.

Примечание

В этом примере кода используется перегрузка метода , отличающаяся от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример до перегрузки, описанной в этой статье, измените selector текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Single обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static float? Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,float?>> selector);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IQueryable<TSource>

Последовательность значений типа TSource.

selector
Expression<Func<TSource,Nullable<Single>>>

Функция проекции, применяемая к каждому элементу.

Возвращаемое значение

Сумма проецированных значений.

Исключения

Параметр source или selector имеет значение null.

Примеры

В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.

Примечание

В этом примере кода используется перегрузка метода , отличающаяся от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример до перегрузки, описанной в этой статье, измените selector текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Int64 обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static long? Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long?>> selector);

Параметры типа

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 текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Double обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static double? Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double?>> selector);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IQueryable<TSource>

Последовательность значений типа TSource.

selector
Expression<Func<TSource,Nullable<Double>>>

Функция проекции, применяемая к каждому элементу.

Возвращаемое значение

Сумма проецированных значений.

Исключения

Параметр source или selector имеет значение null.

Примеры

В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.

Примечание

В этом примере кода используется перегрузка метода , отличающаяся от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример до перегрузки, описанной в этой статье, измените selector текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Int32 обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static int? Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int?>> selector);

Параметры типа

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 текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Int64, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static long Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,long>> selector);

Параметры типа

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 текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений Decimal обнуляемого типа, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static decimal? Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal?>> selector);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IQueryable<TSource>

Последовательность значений типа TSource.

selector
Expression<Func<TSource,Nullable<Decimal>>>

Функция проекции, применяемая к каждому элементу.

Возвращаемое значение

Сумма проецированных значений.

Исключения

Параметр source или selector имеет значение null.

Сумма больше, чем Decimal.MaxValue.

Примеры

В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.

Примечание

В этом примере кода используется перегрузка метода , отличающаяся от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример до перегрузки, описанной в этой статье, измените selector текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Int32, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static int Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,int>> selector);

Параметры типа

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 текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Double, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static double Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,double>> selector);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IQueryable<TSource>

Последовательность значений типа TSource.

selector
Expression<Func<TSource,Double>>

Функция проекции, применяемая к каждому элементу.

Возвращаемое значение

Сумма проецированных значений.

Исключения

Параметр source или selector имеет значение null.

Примеры

В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.

Примечание

В этом примере кода используется перегрузка метода , отличающаяся от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример до перегрузки, описанной в этой статье, измените selector текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>)

Исходный код:
Queryable.cs
Исходный код:
Queryable.cs
Исходный код:
Queryable.cs

Вычисляет сумму последовательности значений типа Decimal, получаемой в результате применения функции проекции к каждому элементу входной последовательности.

C#
public static decimal Sum<TSource> (this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,decimal>> selector);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IQueryable<TSource>

Последовательность значений типа TSource.

selector
Expression<Func<TSource,Decimal>>

Функция проекции, применяемая к каждому элементу.

Возвращаемое значение

Сумма проецированных значений.

Исключения

Параметр source или selector имеет значение null.

Сумма больше, чем Decimal.MaxValue.

Примеры

В следующем примере кода показано, как использовать Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) для суммирования проецируемых значений последовательности.

Примечание

В этом примере кода используется перегрузка метода , отличающаяся от конкретной перегрузки, описанной в этой статье. Чтобы расширить пример до перегрузки, описанной в этой статье, измените selector текст функции.

C#
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
*/

Комментарии

Этот метод имеет по крайней мере один параметр типа 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 свойством Providersource параметра .

Поведение запроса, возникающее в результате выполнения дерева выражений, представляющего вызов Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) , зависит от реализации типа source параметра. Ожидаемое поведение заключается в том, что он вызывает selector для каждого элемента и source возвращает сумму результирующего значения.

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0