3

我正在使用 Automapper 将 EF 对象映射到 DTO;许多对象是多对多排列的。例如:

committee (table) 1 =< m  committeemember (table)  m >= 1 person (table)

这可能映射到:

public class CommitteeViewModel
{
    public int idCommittee { get; set; }
    public IEnumerable<CommitteeMemberViewModel> CommitteeMembers { get; set; }
}

public class CommitteeMemberViewModel
{
    public int idCommittee { get; set; }
    public int idCommitteeMember { get; set; }
    public PersonViewModel Members { get; set; }
}

还有用于<committee, CommitteeViewModel><committeemember, CommitteeMemberViewModel>和的 Automapper 映射<person, PersonViewModel>

当我想归还一个委员会及其成员时,一切都很好。

但是,当我想要一个没有成员的委员会列表时,有没有办法让 Automapper 忽略某些属性,只是为了那个电话?有点像:

var committeeList = Automapper.Mapper.Map
    <List<committee>, List<CommitteeViewModel>>(committees)
   .Ignore("CommitteeMembers");

当然,我可以创建忽略这些属性并映射到这些属性的新 DTO,但由于我基本上想要一个属性之外的所有内容,我认为可能有更好的方法,例如创建不同的映射 - 但我没有设法找到它。

谢谢,

G。

4

1 回答 1

2

您可以通过这种方式获得所需的结果:创建新映射(即覆盖现有映射)、映射源实体并覆盖映射回:

Mapper.CreateMap<committee, CommitteeViewModel>()
      .ForMember(c => c.CommitteeMembers, o => o.Ignore());

var committeeList = Mapper
      .Map<List<committee>, List<CommitteeViewModel>>(committees);

Mapper.CreateMap<committee, CommitteeViewModel>();

但我认为最好保持一致。如果我从委员会映射到 CommitteeViewModel,我希望它每次都会产生相同的结果。因此,最好为“轻”版映射创建新的视图模型。

于 2012-11-19T18:50:47.407 回答