将AutoMapper与DataTable一起使用,缺少列

时间:2013-07-02 19:59:16

标签: c# datatable automapper idatareader

我正在使用AutoMapper将数据表映射到List。

在我的场景中,数据表的列可能会根据外部变量而改变。

我可以成功地将数据表映射到具有以下内容的对象:

AutoMapper.Mapper.CreateMap<IDataReader, Person>();

DataTableReader dtr = myDataTable.CreateDataReader();
List<Person> people = new List<Person>();

people = AutoMapper.Mapper.Map<List<Person>>(dtr);

一切正常。但是我需要将一些属性转换为表中可能存在或不存在的列上的整数。

示例:

AutoMapper.Mapper.CreateMap<IDataReader, Person>()
    .FromMember(dest => dest.NumberOfOrders, opt => opt.MapFrom(src => Convert.ToInt32(src["HowManyOrders"])));

“HowManyOrders”列可能并不总是存在于表中,那么如何检查列是否存在然后转换值呢?

1 个答案:

答案 0 :(得分:1)

你应该可以使用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;
    }