如何使用 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;
}
}
我是 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;
}
}