Queryable.First 方法
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
返回序列的第一个元素。
重载
| 名称 | 说明 |
|---|---|
| First<TSource>(IQueryable<TSource>) |
返回序列的第一个元素。 |
| First<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) |
返回满足指定条件的序列的第一个元素。 |
First<TSource>(IQueryable<TSource>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
返回序列的第一个元素。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static TSource First(System::Linq::IQueryable<TSource> ^ source);
public static TSource First<TSource>(this System.Linq.IQueryable<TSource> source);
[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 TSource First<TSource>(this System.Linq.IQueryable<TSource> source);
static member First : System.Linq.IQueryable<'Source> -> 'Source
[<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 First : System.Linq.IQueryable<'Source> -> 'Source
<Extension()>
Public Function First(Of TSource) (source As IQueryable(Of TSource)) As TSource
类型参数
- TSource
的元素 source的类型。
参数
- source
- IQueryable<TSource>
要 IQueryable<T> 返回的第一个元素。
返回
中的 source第一个元素。
- 属性
例外
source 是 null。
源序列为空。
示例
下面的代码示例演示如何用于 First<TSource>(IQueryable<TSource>) 返回序列中的第一个元素。
int[] numbers = { 9, 34, 65, 92, 87, 435, 3, 54,
83, 23, 87, 435, 67, 12, 19 };
int first = numbers.AsQueryable().First();
Console.WriteLine(first);
/*
This code produces the following output:
9
*/
Dim numbers() As Integer = {9, 34, 65, 92, 87, 435, 3, 54, _
83, 23, 87, 435, 67, 12, 19}
Dim first As Integer = numbers.AsQueryable().First()
MsgBox(first)
' This code produces the following output:
'
' 9
注解
该方法First<TSource>(IQueryable<TSource>)生成一个表示调用First<TSource>(IQueryable<TSource>)自身为已构造泛型方法的一MethodCallExpression个方法。 然后,它将传递给MethodCallExpressionExecute<TResult>(Expression)由参数属性source表示Provider的方法IQueryProvider。
执行表示调用 First<TSource>(IQueryable<TSource>) 的表达式树导致的查询行为取决于参数类型的 source 实现。 预期行为是它返回第一个元素。source
适用于
First<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>)
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
- Source:
- Queryable.cs
返回满足指定条件的序列的第一个元素。
public:
generic <typename TSource>
[System::Runtime::CompilerServices::Extension]
static TSource First(System::Linq::IQueryable<TSource> ^ source, System::Linq::Expressions::Expression<Func<TSource, bool> ^> ^ predicate);
public static TSource First<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,bool>> predicate);
[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 TSource First<TSource>(this System.Linq.IQueryable<TSource> source, System.Linq.Expressions.Expression<Func<TSource,bool>> predicate);
static member First : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, bool>> -> 'Source
[<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 First : System.Linq.IQueryable<'Source> * System.Linq.Expressions.Expression<Func<'Source, bool>> -> 'Source
<Extension()>
Public Function First(Of TSource) (source As IQueryable(Of TSource), predicate As Expression(Of Func(Of TSource, Boolean))) As TSource
类型参数
- TSource
的元素 source的类型。
参数
- source
- IQueryable<TSource>
要从中返回元素的一 IQueryable<T> 个。
- predicate
- Expression<Func<TSource,Boolean>>
用于测试条件的每个元素的函数。
返回
通过测试predicate的第source一个元素。
- 属性
例外
source 或 predicate 为 null.
示例
下面的代码示例演示如何用于 First<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) 返回满足条件的序列的第一个元素。
int[] numbers = { 9, 34, 65, 92, 87, 435, 3, 54,
83, 23, 87, 435, 67, 12, 19 };
// Get the first number in the array that is greater than 80.
int first = numbers.AsQueryable().First(number => number > 80);
Console.WriteLine(first);
/*
This code produces the following output:
92
*/
Dim numbers() As Integer = {9, 34, 65, 92, 87, 435, 3, 54, _
83, 23, 87, 435, 67, 12, 19}
' Get the first number in the array that is greater than 80.
Dim first As Integer = numbers.AsQueryable().First(Function(number) number > 80)
MsgBox(first)
' This code produces the following output:
'
' 92
注解
此方法至少有一个类型 Expression<TDelegate> 参数,其类型参数为类型之 Func<T,TResult> 一。 对于这些参数,可以传入 lambda 表达式,并将它编译为一个 Expression<TDelegate>。
该方法First<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>)生成一个表示调用First<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>)自身为已构造泛型方法的一MethodCallExpression个方法。 然后,它将传递给MethodCallExpressionExecute<TResult>(Expression)由参数属性source表示Provider的方法IQueryProvider。
执行表示调用 First<TSource>(IQueryable<TSource>, Expression<Func<TSource,Boolean>>) 的表达式树导致的查询行为取决于参数类型的 source 实现。 预期行为是它返回满足指定predicate条件的第一个元素source。