如何使用 automapper 将 DataTable 映射到 DTO

How to map DataTable to DTO by using automapper

我是 AutoMapper 的新手,有几个关于数据表到对象映射的问题。我有 sql 查询代码和 sql 结果。我想用自动映射器做对象到对象的映射。有帮助吗?

我想它可能是这样的(粗线):

AutoMapper.Mapper.CreateMap<DataSet, CompanyModel>()
     .ForMember(m => m.Company, opt => opt.MapFrom(r => r.Tables[0].Columns["Company"]))
     .ForMember(m => m.Customers, opt => opt.MapFrom(r => r.Tables[0].Columns["Customers"]))
     .ForMember(m => m.Amount, opt => opt.MapFrom(r => Double.Parse(r.Tables[0].Columns["Amount"]));

然后

Mapper.Map<List<CompanyModel>>(ds);

提供更多详细信息(代码)可能会得到更准确的答案。

如果您使用的是普通无类型 DataTables/DataSets,我认为 Automapper 不支持开箱即用。

但是,如果您创建类型化的 DataTable/DataSet,那么事情应该会更好。键入的 DataSet 为每列提供 table 行属性,并且应该更易于与 AutoMapper 一起使用。

我已经很多年没有使用类型 DataSets,但 .Net 仍然支持它们。 Look here 了解有关如何设置它们的一些信息。

看这里Convert DataRow to Object with AutoMapper

目前我是根据上面的方法做的,到目前为止我只测试了带有原始类型的平面 DTO:

public class CustomResolver : IValueResolver
{
    public ResolutionResult Resolve(ResolutionResult source)
    {
        return source.New(Convert.ChangeType((source.Context.SourceValue as DataRow)[source.Context.MemberName], source.Context.DestinationType));
    }
}


public static class DtoTransformDataTable<T> where T : new()
{
    public static IEnumerable<T> JustDoIt(DataTable dt)
    {
        Mapper.CreateMap<DataRow, T>().ForAllMembers(m => m.ResolveUsing<CustomResolver>());
        var listOfT = new List<T>();

        foreach (var item in dt.Rows) //Use LINQ to concise
        {
            var dest = Mapper.Map<T>(item);
            listOfT.Add(dest);
        }
        return listOfT;
    }
}