今天遇到了AutoMapper的一个性能问题,使用的是AutoMapper的Project特性,AutoMapper版本是3.3.0,代码如下:
return await _repository .GetByStartId(startIngId, itemCount) .Project() .To<TDto>() .ToListAsync();
当获取包含200条数据的列表时,竟然超过5秒。
GetDocs(3000, 200) 6304ms GetDocs(3000, 200) 5822ms GetDocs(3000, 200) 7553ms
而改为100条数据,只需不到10毫秒。
GetDocs(3000, 100) 10ms GetDocs(3000, 100) 7ms GetDocs(3000, 100,) 6ms
相差近千倍,真是不可思议。
不用AutoMapper,直接用Select new {},问题立马解决。
2016年9月15日更新:升级至AutoMapper 5.1.1没出现这个问题。