gpt4 book ai didi

asp.net-mvc-3 - AutoMapper 不会将计算字段映射到标量

转载 作者:行者123 更新时间:2023-12-01 11:49:04 26 4
gpt4 key购买 nike

我试图将我的 MVC3 项目分离到适当的 DAL/Domain/ViewModel 架构中,但我遇到了 AutoMapper 问题,并将计算字段从我的域映射到我的 View 模型。

这是我正在尝试做的一个例子:

界面

public interface IRequirement
{
int Id { get; set; }
... bunch of others
public decimal PlanOct { get; set; }
public decimal PlanNov { get; set; }
public decimal PlanDec { get; set; }
... and so on
decimal PlanQ1 { get; }
... etc
decimal PlanYear { get; }
... repeat for ActualOct, ActualNov ... ActualQ1 ... ActualYear...
}

领域模型

public class Requirement : IRequirement
{
public int Id { get; set; }
... bunch of others
public decimal PlanOct { get; set; }
public decimal PlanNov { get; set; }
public decimal PlanDec { get; set; }
... and so on
public decimal PlanQ1 { get { return PlanOct + PlanNov + PlanDec; } }
... etc
public decimal PlanYear { get { return PlanQ1 + PlanQ2 + PlanQ3 + PlanQ4; } }
... repeat for ActualOct, ActualNov ... ActualQ1 ... ActualYear...
}

还有 VarianceX 属性,即计算为 (PlanOct - ActualOct) 等的 VarianceOct

我的 View 模型看起来几乎完全一样,除了计算字段它具有默认的 getter/setter 语法,例如:

public decimal PlanQ1 { get; set; }

我在 Global.asax 中的 AutoMapper 配置如下所示:

Mapper.CreateMap<Domain.Abstract.IRequirement, Models.Requirement.Details>();

这适用于所有属性,除了计算的属性。我的计算字段(即 *Q1、*Q2、*Q3、*Q4、*Year 和所有 Variance* 字段)都没有实际映射——它们都显示默认值 0.00。

我对此很困惑,而且我也是这个和 AutoMapper 的新手,所以也许我错过了一些东西。我的直觉是,由于属性签名不相同(即域对象只有一个非默认的 getter 而没有 setter,而 View 模型有默认的 getter 和 setter),所以 AutoMapper 没有选择它。但我也这样做了:

Mapper.CreateMap<Domain.Abstract.IRequirement, Models.Requirement.Details>()
.ForMember(dest => dest.PlanQ1, opt => opt.MapFrom(src => src.PlanQ1);

它仍然解析为 0。我也在调试器中确认了这一点。

我做错了什么?

提前致谢。

编辑 1

在听从 Wal 的建议后,我运行了测试并且它成功了,所以我开始一步一步地向后工作,首先将 Field1/Field2/Field3 部分粘贴到接口(interface)/域/ View 模型类中并验证它在我的 Controller ,然后一次改变一件事。我发现,由于我处理的是小数类型,如果我硬编码为整数或 double 值,那么我得到零,但如果我转换为小数或使用小数文字,那么它就可以工作。但前提是我手动设置它们,而不是从数据库中提取值。

换句话说,这是可行的(即 PlanQ1 = 6):

var D = new Requirement { PlanOct = (decimal) 1.0, PlanNov = (decimal) 2.0, PlanDec = (decimal) 3.0 };
var V = Mapper.Map<IRequirement, Details>(D);

这有效:

var D = new Requirement { PlanOct = 1M, PlanNov = 2M, PlanDec = 3M };
var V = Mapper.Map<IRequirement, Details>(D);

但这不是(从存储库对象中提取单个域对象,然后使用 Entity Framework 从 SQL Server 中提取):

var D = requirementRepository.Requirement(5);
var V = Mapper.Map<IRequirement, Details>(D);

通过以上,我得到的 PlanQ1 和 PlanYear 均为 0。我验证了域对象 (D) 中的 PlanOct = 1、PlanNov = 2 和 PlanDec = 3。我还验证了所有对象中的类型,包括 EF 生成的对象,都是十进制的,SQL Server 类型是十进制的。我什至尝试映射到创建的 View 模型,只是为了排除这种可能性,但 PlanQ1 和 PlanYear 仍然为 0:

var D = requirementRepository.Requirement(5);
var V = new Details();
Mapper.Map<IRequirement, Details>(D, V);

最佳答案

PlanQ1IRequirement 的成员吗?你已经暗示它是你的最后一个代码片段,但如果不是,那么你将得到与你描述的完全一样的行为。

考虑一个您正在做的事情的简单示例:

public interface IFoo
{
string Field1 { get; set; }
string Field2 { get; set; }
//string Field3 { get; }
}

public class Foo1 : IFoo
{
public string Field1 { get; set; }
public string Field2 { get; set; }
public string Field3 { get { return Field1 + Field2; } }
}
public class Foo2
{
public string Field1 { get; set; }
public string Field2 { get; set; }
public string Field3 { get; set; }
}

请注意,在这种情况下,我从界面中省略了 Field3;现在,当我运行以下映射时,失败

[TestMethod]
public void Map()
{
Mapper.CreateMap<IFoo, Foo2>();
var foo1 = new Foo1() { Field1 = "field1", Field2 = "field2" };
var foo2 = new Foo2();
Mapper.Map(foo1, foo2);
Assert.AreEqual("field1field2", foo2.Field3);//fails, not mapped
}

因此,如果我在 IFoo 中的 Field3 中发表评论,一切都会恢复正常。使用您的代码检查这个简化示例。

关于asp.net-mvc-3 - AutoMapper 不会将计算字段映射到标量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13407044/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com