我有一个方法返回一个数据表。我认为使用.net 4.0我可以只是异步逻辑并返回数据。但是这段代码返回的是空的Datatable对象。任何想法这个代码有什么问题。使用异步.net 4.0返回DataTable
public DataTable GetData(string sql, string connectionName)
{
DataTable dt = (DataTable)GetDataAsync(sql, connectionName).AsyncState;
return dt;
}
private async Task<DataTable> GetDataAsync(string sql, string connectionName)
{
return await TaskEx.Run(() => { return FillData(sql, connectionName); });
}
private DataTable FillData(string sql, string connectionName)
{
SqlConnection conn = _connections.Where(w => w.ConnectionName == connectionName).Single().Connection;
SqlDataAdapter adp = new SqlDataAdapter(sql, conn);
DataSet ds = new DataSet();
adp.Fill(ds);
return ds.Tables[0];
}
您不能在.NET 4.0或C#4中使用'async' /'await'。这是C#5中的一项新功能,取决于.NET 4.5中的类型。 –
乔恩 - 因为他使用TaskEx.Run,我猜他正在使用异步定位包,它可以让你定位4.0并使用异步/等待 –