DataReaderExtensions.GetFieldValueAsync<T> Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Obtient de façon asynchrone la valeur de la colonne spécifiée comme type demandé.
public static System.Threading.Tasks.Task<T> GetFieldValueAsync<T>(this System.Data.Common.DbDataReader reader, string name, System.Threading.CancellationToken cancellationToken = default);
static member GetFieldValueAsync : System.Data.Common.DbDataReader * string * System.Threading.CancellationToken -> System.Threading.Tasks.Task<'T>
<Extension()>
Public Function GetFieldValueAsync(Of T) (reader As DbDataReader, name As String, Optional cancellationToken As CancellationToken = Nothing) As Task(Of T)
Paramètres de type
- T
Type de la valeur à renvoyer.
Paramètres
- reader
- DbDataReader
Lecteur de données à partir duquel obtenir la valeur de colonne.
- name
- String
Nom de la colonne.
- cancellationToken
- CancellationToken
Jeton facultatif pour annuler l’opération asynchrone.
Retours
Tâche dont Result la valeur contient la colonne spécifiée.
Exceptions
La connexion a été supprimée ou fermée lors de la récupération des données.
-ou-
Le lecteur de données a été fermé pendant la récupération des données.
-ou-
Il n’y a pas de données prêtes à être lues (par exemple, la première Read() n’a pas été appelée, ou elle est retournée false).
-ou-
Tentative de lecture d’une colonne lue précédemment en mode séquentiel.
-ou-
Une opération asynchrone s’est déroulée en cours. Cela s’applique à toutes les méthodes Get_*_ lors de l’exécution en mode séquentiel, car elles peuvent être appelées lors de la lecture d’un flux.
Le nom spécifié n’est pas un nom de colonne valide.
La valeur retournée par la base de données ne correspond pas ou ne peut pas être convertie en T.
Le jeton d’annulation a été annulé. Cette exception est stockée dans la tâche retournée.
Remarques
Cette méthode asynchrone est uniquement nécessaire pour éviter de bloquer le thread appelant lorsque le lecteur est créé en mode séquentiel.
Si le mode séquentiel n’est pas spécifié, toutes les valeurs de colonne doivent être disponibles en mémoire chaque fois que ReadAsync se termine et l’appel de la version synchrone de la méthode ne doit pas bloquer le thread appelant.
L’implémentation par défaut de cette méthode asynchrone appelle son équivalent synchrone et retourne une tâche terminée, ce qui peut bloquer le thread appelant. L’implémentation par défaut retourne également une tâche annulée si elle a passé un jeton d’annulation déjà annulé.
Les fournisseurs de données qui prennent en charge la programmation asynchrone doivent remplacer l’implémentation par défaut à l’aide d’opérations d’E/S asynchrones.
Cette méthode accepte un jeton d’annulation qui peut être utilisé pour demander l’annulation anticipée de l’opération. Les implémentations peuvent ignorer cette demande.
Les autres méthodes et propriétés de l’objet DbDataReader ne doivent pas être appelées alors que la tâche retournée n’est pas encore terminée.