我最近开始使用 Automapper。我有包含 50 个属性的大数据库表。 我想使用 Automapper 更新表,但只有少数选定的属性将使用 viewmodel 传递。
为了让我的问题简单化,我编写了小型控制台程序。
internal class Person
{
public string FirstName { get; set; }
public string NickName { get; set; }
public string LastName { get; set; }
}
internal class PersonContract
{
public string FirstName { get; set; }
public string NickName { get; set; }
public string LastName { get; set; }
}
class Program
{
static void Main(string[] args)
{
PersonContract Person1 = new PersonContract { NickName = "Dan", LastName = "Smith" };
Person Person2 = new Person { FirstName = "Robert", NickName = "Rob" };
Mapper.CreateMap<PersonContract, Person>();
Mapper.Map(Person1, Person2);
Console.WriteLine(Person2.FirstName);
Console.WriteLine(Person2.NickName);
Console.WriteLine(Person2.LastName);
Console.ReadLine();
}
}
我的输出是 无效的 担 史密斯
我很期待 罗伯特 担 史密斯
因为如果 Person1 没有传递“Firstname”,那么 Person2 应该保留旧值。 显然我没有正确理解它。 谁能解释这个问题?并让我知道如何获得我期望的输出。
最佳答案
默认情况下 Automapper 将复制所有属性,无论它们是否为空,但您可以使用 ForAllMembers
和 Condition 设置所有成员都满足的条件
方法。
在您的情况下,您可以检查 IsSourceValueNull
属性:
Mapper.CreateMap<PersonContract, Person>()
.ForAllMembers(cfg => cfg.Condition(rc => !rc.IsSourceValueNull));
关于c# - 使用 Automapper 仅更新少数属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37334720/