Сначала я опробую код Entity Framework CTP4. Предположим, у меня есть:
public class Parent
{
public int Id { get; set; }
public string Name { get; set; }
}
public class Child
{
public int Id { get; set; }
public string Name { get; set; }
public Parent Mother { get; set; }
}
public class TestContext : DbContext
{
public DbSet<Parent> Parents { get; set; }
public DbSet<Child> Children { get; set; }
}
public class ChildEdit
{
public int Id { get; set; }
public string Name { get; set; }
public int MotherId { get; set; }
}
Mapper.CreateMap<Child, ChildEdit>();
Сопоставление с моделью редактирования не является проблемой. На моем экране я выбираю мать с помощью какого-либо элемента управления (выпадающий список, автозаполнение и т. Д.), И идентификатор матери отправляется обратно:
[HttpPost]
public ActionResult Edit(ChildEdit posted)
{
var repo = new TestContext();
var mapped = Mapper.Map<ChildEdit, Child>(posted); // <------- ???????
}
Как мне решить последнее сопоставление? Я не хочу помещать Mother_Id в объект Child. Пока я использую это решение, но я надеюсь, что оно может быть решено в Automapper.
Mapper.CreateMap<ChildEdit, Child>()
.ForMember(i => i.Mother, opt => opt.Ignore());
var mapped = Mapper.Map<ChildEdit, Child>(posted);
mapped.Mother = repo.Parents.Find(posted.MotherId);
EDIT
Это работает, но теперь я должен сделать это для каждого внешнего ключа (кстати, контекст будет введен в окончательном решении):
Mapper.CreateMap<ChildEdit, Child>();
.ForMember(i => i.Mother,
opt => opt.MapFrom(o =>
new TestContext().Parents.Find(o.MotherId)
)
);
Что бы я действительно хотел, так это:
Mapper.CreateMap<int, Parent>()
.ForMember(i => i,
opt => opt.MapFrom(o => new TestContext().Parents.Find(o))
);
Mapper.CreateMap<ChildEdit, Child>();
Возможно ли это с Automapper?