Queryable.Sum 方法
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
计算数值序列的和。
重载
Sum(IQueryable<Decimal>)
计算 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
。
注解
该方法Sum(IQueryable<Decimal>)生成一个表示调用Sum(IQueryable<Decimal>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Decimal>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值的总 source
和。
适用于
Sum(IQueryable<Double>)
计算 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>)生成一个表示调用Sum(IQueryable<Double>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Double>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Int32>)
计算 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
。
注解
该方法Sum(IQueryable<Int32>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Int32>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Int32>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Int64>)
计算 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
。
注解
该方法Sum(IQueryable<Int64>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Int64>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Int64>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Nullable<Decimal>>)
计算可以为 null 的 Decimal 值序列的总和。
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>>
要计算其总和的可以为 null 的 Decimal 值序列。
返回
序列中的值的总和。
例外
source
为 null
。
注解
该方法Sum(IQueryable<Nullable<Decimal>>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Nullable<Decimal>>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Nullable<Decimal>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Nullable<Double>>)
计算可以为 null 的 Double 值序列的总和。
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>>
要计算其总和的可以为 null 的 Double 值序列。
返回
序列中的值的总和。
例外
source
为 null
。
注解
该方法Sum(IQueryable<Nullable<Double>>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Nullable<Double>>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Nullable<Double>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Nullable<Int32>>)
计算可以为 null 的 Int32 值序列的总和。
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>>
要计算其总和的可以为 null 的 Int32 值序列。
返回
序列中的值的总和。
例外
source
为 null
。
注解
该方法Sum(IQueryable<Nullable<Int32>>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Nullable<Int32>>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Nullable<Int32>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Nullable<Int64>>)
计算可以为 null 的 Int64 值序列的总和。
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>>
要计算其总和的可以为 null 的 Int64 值序列。
返回
序列中的值的总和。
例外
source
为 null
。
注解
该方法Sum(IQueryable<Nullable<Int64>>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Nullable<Int64>>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Nullable<Int64>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Nullable<Single>>)
计算可以为 null 的 Single 值序列的总和。
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>>
要计算其总和的可以为 null 的 Single 值序列。
返回
序列中的值的总和。
例外
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>>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Nullable<Single>>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Nullable<Single>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum(IQueryable<Single>)
计算 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>)生成一个表示自己作为构造泛型方法调用Sum(IQueryable<Single>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum(IQueryable<Single>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是它返回值 source
的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>)
计算可以为 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);
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
。
示例
下面的代码示例演示如何用于 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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int32>>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>)
计算 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);
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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Single>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>)
计算可以为 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);
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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Single>>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>)
计算可以为 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);
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
。
示例
下面的代码示例演示如何用于 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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Int64>>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>)
计算可以为 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);
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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Double>>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>)
计算 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);
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
。
示例
下面的代码示例演示如何用于 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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int64>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>)
计算 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);
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
。
示例
下面的代码示例演示如何用于 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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Int32>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>)
计算 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);
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> 一。 对于这些参数,可以传入 lambda 表达式,并将它编译为一个 Expression<TDelegate>。
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>)生成一个表示自己作为构造泛型方法调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Double>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它在每个元素source
上调用selector
并返回生成的值之和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>)
计算 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);
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
。
示例
下面的代码示例演示如何用于 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> 一。 对于这些参数,可以传入 lambda 表达式,并将它编译为一个 Expression<TDelegate>。
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>)生成一个表示自己作为构造泛型方法调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>)自身的方法MethodCallExpression。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Decimal>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它在每个元素source
上调用selector
并返回生成的值之和。
适用于
Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>)
计算可以为 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);
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
。
示例
下面的代码示例演示如何用于 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> 一。 For these parameters, you can pass in a lambda expression and it will be compiled to an Expression<TDelegate>.
该方法Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>)生成一个表示调用Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>)本身为构造泛型方法的一个MethodCallExpression方法。 然后,MethodCallExpressionExecute<TResult>(Expression)它将传递给由参数属性source
表示Provider的方法IQueryProvider。
执行表示调用 Sum<TSource>(IQueryable<TSource>, Expression<Func<TSource,Nullable<Decimal>>>) 的表达式树导致的查询行为取决于参数类型的 source
实现。 预期行为是,它会对每个元素source
调用selector
并返回结果值的总和。