我正在使用AutoMapper将数据表映射到List。
在我的场景中,数据表的列可能会根据外部变量而更改。
我可以成功地将数据表映射到以下对象:
AutoMapper.Mapper.CreateMap<IDataReader, Person>();
DataTableReader dtr = myDataTable.CreateDataReader();
List<Person> people = new List<Person>();
people = AutoMapper.Mapper.Map<List<Person>>(dtr);
这一切都很好。但是,对于表中可能存在或不存在的列,我需要将一些属性转换为integer。
示例:
AutoMapper.Mapper.CreateMap<IDataReader, Person>()
.FromMember(dest => dest.NumberOfOrders, opt => opt.MapFrom(src => Convert.ToInt32(src["HowManyOrders"])));
"HowManyOrders"列可能并不总是存在于表中,那么我该如何检查该列是否存在,如果存在则转换值呢?
您应该能够使用AfterMap:
Mapper.CreateMap<IDataReader, Person>()
.AfterMap((source, dest) =>
{
if (ColumnExists(source, "HowManyOrders"))
{
dest.NumberOfOrders =
Convert.ToInt32(source["HowManyOrders"]);
}
});
...
public bool ColumnExists(IDataReader reader, string columnName)
{
for (int i = 0; i < reader.FieldCount; i++)
{
if (reader.GetName(i) == columnName)
{
return true;
}
}
return false;
}