AutoMapper - 使用相同的源和目标对象类型映射

时间:2012-04-02 16:42:21

标签: c# automapper

我正在使用Automapper来获取两个相同类型的对象,并映射已更改的任何新值。我尝试使用下面的代码,但它不断抛出错误,我甚至不确定这是否可以通过Automapper实现。

例如:

        Mapper.CreateMap<UserDetails, UserDetails>();
        UserDetails userDetails = Mapper.Map<UserDetails, UserDetails>(userDetailsCurrent, userDetailsNew);

基本上,我需要将来自新对象“userDetailsNew”的任何新值复制到现有对象“userDetailsCurrent” - 即使它们属于同一类型。这样我就可以用新值“更新”现有对象。我这样做的原因是因为我不确定将传递哪些用户详细信息 - 我需要在它们到达时映射它们。

我通常使用Automapper来映射具有相似属性的不同对象 - 但我认为我可以使用Automapper的强大功能以这种方式实现相同的功能。甚至可能有更好的解决方案 - 任何帮助都会受到赞赏!

3 个答案:

答案 0 :(得分:7)

这似乎对我有用。我的自定义类型:

class MyType
{
    public int MyInt { get; set; }
    public string MyString { get; set; }
}

我的地图代码:

Mapper.CreateMap<MyType, MyType>();
var source = new MyType() {MyInt = 1, MyString = "Hello world"};
var dest = Mapper.Map<MyType, MyType>(source);

除了简单属性之外,您的自定义类型有什么有趣的地方?

答案 1 :(得分:4)

这可以使用元组和创建从Automapper的Abstract TypeConverter类派生的自定义类型转换器来完成。

假设您有源和目标类:

public class Person
{
    public string FirstName { get; set; }
    public string LastName { get; set; }

    public override string ToString()
    {
        return string.Format("Firstname: {0}, Lastname: {1}", FirstName, LastName);
    }
}

然后您可以将自定义转换器类型构建为

public class CustomerPersonConverter : TypeConverter<Tuple<Person, Person>, Person>
{
    protected override Person ConvertCore(Tuple<Person, Person> source)
    {
        var orginalValues = source.Item1;
        var updatedValues = source.Item2;

        var result = new Person
            {
                FirstName = string.IsNullOrEmpty(updatedValues.FirstName) ? orginalValues.FirstName : updatedValues.FirstName,
                LastName = string.IsNullOrEmpty(updatedValues.LastName) ? orginalValues.LastName : updatedValues.LastName
            };

        return result;
    }
}

可以像

一样使用
var orginal = new Person() {FirstName = "Clifford", LastName = "Mayson"};
        var updated = new Person() {FirstName = "Cliff"};

        Mapper.CreateMap<Tuple<Person, Person>, Person>().ConvertUsing<CustomerPersonConverter>();

        var result = Mapper.Map<Person>(new Tuple<Person, Person>(orginal, updated));

        Console.WriteLine(result);

这将产生保持原始姓氏值的结果,因为更新中缺少原始姓氏值,但更新名字值,例如。

Firstname: Cliff, Lastname: Mayson

答案 2 :(得分:1)

这是Automapper(see issue)的已知行为。您实际上必须告诉Automapper:

CreateMap<A,A>();
CreateMap<B,B>();
CreateMap<C,C>();