我正在尝试学习如何使用await和async。
我有一个服务层,它有一个参考数据管理器。我的界面是:
public interface IReferenceDataService
{
Task<List<ReferenceItemDto>> GetAsync(ReferenceTypes type);
}
当我尝试在UI中获取数据时,我这样做:
model.DeptPaymentTypes = _refDataService.GetAsync(Enums.ReferenceTypes.DeptPaymentTypes)
.Select(x => new SelectListItem {
Text = x.Description,
Value = x.Id.ToString() })
.ToList();
但是我收到一个错误,&#34; ToList不是Task&lt; ...&#34;
的定义我的数据层调用使用Dapper QueryAsync ...
获取数据 public async Task<List<ReferenceItemDto>> GetAsync(Enums.ReferenceTypes type)
{
var table = string.Empty;
if(type == Enums.ReferenceTypes.DaysOfMonth)
{
var days = new List<ReferenceItemDto>();
for (int i = 1; i <= 31; i++)
{
days.Add(new ReferenceItemDto
{
Description = i.ToString(),
Id = i
});
}
return days;
}
switch (type)
{
case Enums.ReferenceTypes.SnowballTypes:
table = "SnowballType";
break;
case Enums.ReferenceTypes.DeptPaymentTypes:
table = "DebtPaymentType";
break;
default:
throw new System.Exception("Unknown data type in referenc manager.");
}
using (IDbConnection db = new SqlConnection("Data Source=......"))
{
var data = await db.QueryAsync<ReferenceItemDto>("GetReferenceDataList", new { DataType = table }, commandType: CommandType.StoredProcedure);
return data.ToList();
}
}
我做错了什么? ToList给我带来了一个问题。
答案 0 :(得分:5)
您应该从异步方法获得结果。
最好避免阻止Result
之类的调用,因此请改用await
。
model.DeptPaymentTypes = (await _refDataService.GetAsync(Enums.ReferenceTypes.DeptPaymentTypes))
.Select(x => new SelectListItem {
Text = x.Description,
Value = x.Id.ToString() })
.ToList();
答案 1 :(得分:4)
尝试使用
model.DeptPaymentTypes = _refDataService.GetAsync(Enums.ReferenceTypes.DeptPaymentTypes).Result
.Select(x => new SelectListItem {
Text = x.Description,
Value = x.Id.ToString() })
.ToList();