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


QueryableExtensions.SingleAsync<TSource> - метод (IQueryable<TSource>, Expression<Func<TSource, Boolean>>)

[Эта страница относится к документации к Entity Framework 6. Последняя версия доступна в составе пакета Entity Framework NuGet. Дополнительные сведения об Entity Framework см. в разделе msdn.com/data/ef.]

Асинхронно возвращает единственный элемент последовательности, удовлетворяющий заданному условию, и вызывает исключение, если существуют несколько таких элементов.

Пространство имен:  System.Data.Entity
Сборка:  EntityFramework (в EntityFramework.dll)

Синтаксис

'Декларация
<SuppressMessageAttribute("Microsoft.Design", "CA1006:DoNotNestGenericTypesInMemberSignatures")> _
<ExtensionAttribute> _
Public Shared Function SingleAsync(Of TSource) ( _
    source As IQueryable(Of TSource), _
    predicate As Expression(Of Func(Of TSource, Boolean)) _
) As Task(Of TSource)
'Применение
Dim source As IQueryable(Of TSource)
Dim predicate As Expression(Of Func(Of TSource, Boolean))
Dim returnValue As Task(Of TSource)

returnValue = source.SingleAsync(predicate)
[SuppressMessageAttribute("Microsoft.Design", "CA1006:DoNotNestGenericTypesInMemberSignatures")]
public static Task<TSource> SingleAsync<TSource>(
    this IQueryable<TSource> source,
    Expression<Func<TSource, bool>> predicate
)
[SuppressMessageAttribute(L"Microsoft.Design", L"CA1006:DoNotNestGenericTypesInMemberSignatures")]
[ExtensionAttribute]
public:
generic<typename TSource>
static Task<TSource>^ SingleAsync(
    IQueryable<TSource>^ source, 
    Expression<Func<TSource, bool>^>^ predicate
)
[<SuppressMessageAttribute("Microsoft.Design", "CA1006:DoNotNestGenericTypesInMemberSignatures")>]
static member SingleAsync : 
        source:IQueryable<'TSource> * 
        predicate:Expression<Func<'TSource, bool>> -> Task<'TSource> 
JScript does not support generic types and methods.

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

  • TSource
    Тип элементов последовательности source.

Параметры

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

Тип: System.Threading.Tasks.Task<TSource>
Задача, представляющая асинхронную операцию.Результат задачи содержит единственный элемент во входящей последовательности, который удовлетворяет условию в predicate.

Примечание об использовании

В Visual Basic и C# этот метод можно вызывать как метод экземпляра для любого объекта типа IQueryable<TSource>. При вызове метода для экземпляра следует опускать первый параметр. Дополнительные сведения см. в разделе https://msdn.microsoft.com/ru-ru/library/bb384936(v=vs.113) или https://msdn.microsoft.com/ru-ru/library/bb383977(v=vs.113).

Исключения

Исключение Условие
ArgumentNullException

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

InvalidOperationException

source не реализует IDbAsyncQueryProvider.

InvalidOperationException

Ни один элемент не удовлетворяет условию в predicate.

InvalidOperationException

Условию в predicate удовлетворяют больше одного элемента.

Примечания

Несколько активных операций в одном экземпляре контекста не поддерживается. Используйте «await» для обеспечения того, чтобы все асинхронные операции завершались перед вызовом другого метода применительно к этому контексту.

См. также

Справочник

QueryableExtensions Класс

SingleAsync - перегрузка

System.Data.Entity - пространство имен