다음을 통해 공유


DbDataReader.GetFieldValueAsync 메서드

정의

지정된 열의 값을 요청된 형식으로 비동기적으로 가져옵니다.

오버로드

GetFieldValueAsync<T>(Int32)

지정된 열의 값을 요청된 형식으로 비동기적으로 가져옵니다.

GetFieldValueAsync<T>(Int32, CancellationToken)

지정된 열의 값을 요청된 형식으로 비동기적으로 가져옵니다.

GetFieldValueAsync<T>(Int32)

Source:
DbDataReader.cs
Source:
DbDataReader.cs
Source:
DbDataReader.cs

지정된 열의 값을 요청된 형식으로 비동기적으로 가져옵니다.

public:
generic <typename T>
 System::Threading::Tasks::Task<T> ^ GetFieldValueAsync(int ordinal);
public System.Threading.Tasks.Task<T> GetFieldValueAsync<T> (int ordinal);
member this.GetFieldValueAsync : int -> System.Threading.Tasks.Task<'T>
Public Function GetFieldValueAsync(Of T) (ordinal As Integer) As Task(Of T)

형식 매개 변수

T

반환될 값의 형식입니다.

매개 변수

ordinal
Int32

열 서수(0부터 시작)입니다.

반환

Task<T>

Result에 지정된 열의 값을 포함하는 작업입니다.

예외

데이터를 검색하는 동안 연결이 끊어졌거나 닫혔습니다.

또는

데이터를 검색하는 동안 데이터 판독기가 닫혔습니다.

또는

읽을 준비가 된 데이터가 없습니다(예를 들어, 첫 번째 Read()가 호출되지 않았거나 false를 반환함).

또는

순차 모드에서 이전에 읽은 열을 읽으려고 했습니다.

또는

진행 중인 비동기 작업이 없습니다. 이는 스트림을 읽는 동안 호출할 수 있기 때문에 순차 모드로 실행할 때 모든 Get_*_ 메서드에 적용됩니다.

열 인덱스가 범위를 벗어났습니다.

데이터베이스에서 반환되는 값이 일치하지 않거나 이 값을 T에 캐스팅할 수 없습니다.

설명

이 비동기 메서드는 판독기가 순차 모드로 생성될 때 호출 스레드를 차단하지 않도록 하기 위해서만 필요합니다.

순차 모드를 지정하지 않으면 ReadAsync가 완료될 때마다 모든 열 값을 메모리에서 사용할 수 있게 되며, 메서드의 동기 버전을 호출해도 호출 스레드를 차단하면 안 됩니다.

이 비동기 메서드의 기본 구현은 동기 대응 메서드를 호출하고 완료된 Task를 반환하여 호출 스레드를 차단할 수 있습니다.

비동기 프로그래밍을 지원하는 데이터 공급자는 비동기 I/O 작업을 사용하여 기본 구현을 재정의해야 합니다.

반환된 작업이 아직 완료되지 않은 상태에서는 DbDataReader 개체의 다른 메서드와 속성을 호출하면 안 됩니다.

적용 대상

GetFieldValueAsync<T>(Int32, CancellationToken)

Source:
DbDataReader.cs
Source:
DbDataReader.cs
Source:
DbDataReader.cs

지정된 열의 값을 요청된 형식으로 비동기적으로 가져옵니다.

public:
generic <typename T>
 virtual System::Threading::Tasks::Task<T> ^ GetFieldValueAsync(int ordinal, System::Threading::CancellationToken cancellationToken);
public virtual System.Threading.Tasks.Task<T> GetFieldValueAsync<T> (int ordinal, System.Threading.CancellationToken cancellationToken);
abstract member GetFieldValueAsync : int * System.Threading.CancellationToken -> System.Threading.Tasks.Task<'T>
override this.GetFieldValueAsync : int * System.Threading.CancellationToken -> System.Threading.Tasks.Task<'T>
Public Overridable Function GetFieldValueAsync(Of T) (ordinal As Integer, cancellationToken As CancellationToken) As Task(Of T)

형식 매개 변수

T

반환될 값의 형식입니다.

매개 변수

ordinal
Int32

열 서수(0부터 시작)입니다.

cancellationToken
CancellationToken

비동기 작업을 취소하기 위한 토큰입니다.

반환

Task<T>

Result에 지정된 열의 값을 포함하는 작업입니다.

예외

데이터를 검색하는 동안 연결이 끊어졌거나 닫혔습니다.

또는

데이터를 검색하는 동안 데이터 판독기가 닫혔습니다.

또는

읽을 준비가 된 데이터가 없습니다(예를 들어, 첫 번째 Read()가 호출되지 않았거나 false를 반환함).

또는

순차 모드에서 이전에 읽은 열을 읽으려고 했습니다.

또는

진행 중인 비동기 작업이 없습니다. 이는 스트림을 읽는 동안 호출할 수 있기 때문에 순차 모드로 실행할 때 모든 Get_*_ 메서드에 적용됩니다.

열 인덱스가 범위를 벗어났습니다.

데이터베이스에서 반환되는 값이 일치하지 않거나 이 값을 T에 캐스팅할 수 없습니다.

취소 토큰이 취소되었습니다. 이 예외는 반환된 작업에 저장됩니다.

설명

이 비동기 메서드는 판독기가 순차 모드로 생성될 때 호출 스레드를 차단하지 않도록 하기 위해서만 필요합니다.

순차 모드를 지정하지 않으면 ReadAsync가 완료될 때마다 모든 열 값을 메모리에서 사용할 수 있게 되며, 메서드의 동기 버전을 호출해도 호출 스레드를 차단하면 안 됩니다.

이 비동기 메서드의 기본 구현은 동기 대응 메서드를 호출하고 완료된 Task를 반환하여 호출 스레드를 차단할 수 있습니다. 또한 기본 구현은 이미 취소된 취소 토큰을 전달한 경우 취소된 작업을 반환합니다.

비동기 프로그래밍을 지원하는 데이터 공급자는 비동기 I/O 작업을 사용하여 기본 구현을 재정의해야 합니다.

이 메서드는 조기에 취소할 작업을 요청하는 데 사용할 수 있는 취소 토큰을 허용합니다. 구현은 이 요청을 무시할 수 있습니다.

반환된 작업이 아직 완료되지 않은 상태에서는 DbDataReader 개체의 다른 메서드와 속성을 호출하면 안 됩니다.

적용 대상