【问题标题】:AutoMapper complex object mapping - mapping a listAutoMapper 复杂对象映射 - 映射一个列表
【发布时间】:2012-10-16 14:03:19
【问题描述】:

我有以下课程。领域模型由实体框架创建,我正在使用 POCO。

public class Customer
{
    public int Id { get; set; }
    public string Name { get; set; }
    public DateTime CreatedDate{ get; set; }
    public DateTime ModifiedDate{ get; set; }
    public virtual ICollection<Order> Orders{ get; set; }
}

public class CustomerDTO
{

    public int Id { get; set; }
    public string Name{ get; set; }
    public List<OrderDTO> Orders{ get; set; }
}

public class Order
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int ProductId { get; set; }
    public DateTime CreatedDate{ get; set; }
    public DateTime ModifiedDate{ get; set; }
}

public class OrderDTO
{
    public int Id { get; set; }
    public string Name{ get; set; }
}

我尝试了以下映射。

Mapper.CreateMap<Customer, CustomerDTO>();
Mapper.CreateMap<CustomerDTO, Customer>();
Mapper.CreateMap<Order, OrderDTO>();
Mapper.CreateMap<OrderDTO, Order>();

我也试过了

Mapper.CreateMap<CustomerDTO, Customer>().ForMember(c => c.Orders,
            m => m.MapFrom
            (
                q => Mapper.Map<List<OrderDTO>, ICollection<Order>>(q.Orders)
            )
        );

为了更新客户,我从数据库中检索它并使用 customerDTO 更新它

Customer customer = _customerRepository.GetById(customerDTO.Id);
Mapper.Map<CustomerDTO, Customer>(customerDTO, customer);

客户对象正在正确更新,并且创建和修改日期未更改。但是订单列表中的每个订单都没有正确更新。它的 productId、创建和修改日期被设置为默认值,而不是从数据库中检索到的值。

因为 Orders 是一个虚拟集合,我需要做其他事情吗?

我是自动映射器的新手,任何帮助表示赞赏。

编辑

我加了

Mapper.AssertConfigurationIsValid();

在应用启动时收到以下错误: 未映射的成员被发现。查看下面的类型和成员。 添加自定义映射表达式、忽略、添加自定义解析器或修改源/目标类型

我将映射更新为:

Mapper.CreateMap<OrderDTO, Order>()
                .ForMember(x => x.CreatedDate, y => y.Ignore())
                .ForMember(x => x.ModifiedDate, y => y.Ignore())
                .ForMember(x => x.ProductId, y => y.Ignore())

但是订单的上述属性仍然被默认值覆盖

【问题讨论】:

  • 同样的问题!做“地图”=属性“Id”和“UpdateDate”将被设置为默认值,而不是忽略它作为“CreateMap”定义...你找到解决方案了吗??

标签: automapper automapper-2


【解决方案1】:

我不确定它是否是正确或最佳的解决方案,但您可以在映射中尝试更改

q => Mapper.Map<List<OrderDTO>, ICollection<Order>>(q.Orders)

q => Mapper.Map<List<OrderDTO>, ICollection<Order>>(q.Orders, c.Orders)

这应该更新而不是覆盖订单(类似于您的客户地图)。

请注意,仅使用以下内容就足够了:

q => Mapper.Map(q.Orders, c.Orders)

旁白:

还有一件小事,我发现在使用与文档中类似的约定时更容易阅读映射。 For example:

// Configure AutoMapper
Mapper.CreateMap<CalendarEvent, CalendarEventForm>()
    .ForMember(dest => dest.EventDate, opt => opt.MapFrom(src => src.EventDate.Date))
    .ForMember(dest => dest.EventHour, opt => opt.MapFrom(src => src.EventDate.Hour))
    .ForMember(dest => dest.EventMinute, opt => opt.MapFrom(src => src.EventDate.Minute));

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-04-19
    • 2019-03-30
    • 2020-04-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多