DataReaderExtensions.GetFieldValueAsync<T> Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Asynchronně získá hodnotu zadaného sloupce jako požadovaný typ.
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)
Parametry typu
- T
Typ hodnoty, která má být vrácena.
Parametry
- reader
- DbDataReader
Čtečka dat, ze které chcete získat hodnotu sloupce.
- name
- String
Název sloupce
- cancellationToken
- CancellationToken
Volitelný token pro zrušení asynchronní operace.
Návraty
Úkol, který Result obsahuje hodnotu zadaného sloupce.
Výjimky
Připojení bylo ukončeno nebo ukončeno během načítání dat.
-nebo-
Při načítání dat se zavřela čtečka dat.
-nebo-
Nejsou připravená žádná data ke čtení (například první Read() nebyla volána nebo vrácena false
).
-nebo-
Pokusili jste se přečíst dříve přečtený sloupec v sekvenčním režimu.
-nebo-
Probíhala asynchronní operace. To platí pro všechny metody Get_*_ spuštěné v sekvenčním režimu, protože je možné je volat při čtení datového proudu.
Zadaný název není platným názvem sloupce.
Hodnota vrácená databází se neshoduje nebo ji nelze přetypovat na T
.
Token zrušení byl zrušen. Tato výjimka se uloží do vrácené úlohy.
Poznámky
Tato asynchronní metoda je nutná pouze k tomu, aby se zabránilo blokování volající vlákno, když je čtečka vytvořena v sekvenčním režimu.
Pokud není zadaný sekvenční režim, měly by být všechny hodnoty sloupců k dispozici v paměti při každém dokončení readAsync a volání synchronní verze metody by nemělo blokovat volající vlákno.
Výchozí implementace této asynchronní metody vyvolá její synchronní protějšek a vrátí dokončenou úlohu, potenciálně blokuje volající vlákno. Výchozí implementace také vrátí zrušenou úlohu, pokud byl předán již zrušený token zrušení.
Zprostředkovatelé dat, kteří podporují asynchronní programování , by měli přepsat výchozí inmplementaci pomocí asynchronních vstupně-výstupních operací.
Tato metoda přijímá token zrušení, který lze použít k žádosti o předčasné zrušení operace. Implementace můžou tento požadavek ignorovat.
Jiné metody a vlastnosti DbDataReader objektu by neměly být vyvolány, dokud vrácená úloha ještě není dokončena.