IAsyncEnumerable 不包含 ADO.NET 中“GetAwaiter”的定义

Ole*_*our 1 c# iasyncenumerable .net-core-3.1

.Net Core 3.1, C# 8 中的这段代码:

 await  dB.GetListAsync<OrigineDB>();  
Run Code Online (Sandbox Code Playgroud)

导致此错误:

IAsyncEnumerable 不包含“GetAwaiter”的定义

此处提供的答案:https : //stackoverflow.com/a/60148747/4180382对我没有太大帮助,因为我的方法包含示例中的产量和循环。

我应该做哪些改变?我不想返回一个列表。

 async IAsyncEnumerable<T> GetListAsync<T>() where T : class, new()
        {
            cn = new SqlConnection(cs);
            cn.Open();
            cmd = new SqlCommand(nameProcStock, cn);
            cmd.CommandType = CommandType.StoredProcedure;

            if (parms != null)
                foreach (KeyValuePair<string, object> kvp in parms)
                    cmd.Parameters.AddWithValue(kvp.Key, kvp.Value);

            dr = await cmd.ExecuteReaderAsync();
            while (dr.Read())
                yield return ConvertToObject<T>();
        }
Run Code Online (Sandbox Code Playgroud)

Ack*_*ari 6

如果方法返回该类型的对象,则IAsyncEnumerable<T>您不能等待它,实际上您不必等待。您可以简单地在异步 foreach 循环中使用它,并在循环体中使用它的内容。

你可以这样消费IAsyncEnumerable<T>

await foreach (var item in db.GetListAsync<OrigineDB>()) 
{
    // do what ever you want
}
Run Code Online (Sandbox Code Playgroud)