首页 > 解决方案 > 将 DTO 映射到 EF 实体时处理关系

问题描述

在我的 DTO 中,我发送 Id 而不是整个对象来将一个对象分配/关联到另一个对象。问题是我的映射代码需要访问数据库来处理这个问题,因为我的实体类没有BarId属性。

public class FooDTO
{
    public int FooId { get; set; }
    public int BarId { get; set; }
}

public class Foo
{
    public int FooId { get; set; }
    public Bar Bar { get; set; }
}

这可能可以通过BarId向我的实体类添加额外的属性来解决,这样我就不会将数据访问与我的映射器结合起来。

但是问题来了:如果指定 id 的 bar 不存在,是否可以以某种合理的方式处理以返回自定义错误消息?

public class Foo
{
    public int FooId { get; set; }
    public int? BarId { get; set; }
    public Bar Bar { get; set; }
}

BarId是否可以在我的映射代码中访问数据库并手动处理这些分配,或者通过在我的实体类中显式添加外键属性 () 将其留给 ORM 更好?

另请参阅:https ://docs.microsoft.com/en-us/ef/core/modeling/relationships#no-foreign-key-property

虽然建议在依赖实体类中定义外键属性,但这不是必需的。

似乎建议添加外键属性,所以我想我会选择这条路线。

标签: c#entity-framework-coreautomapperasp.net-core-webapidto

解决方案


不,不好。如果您正在访问数据库,这绝对不是映射代码。


推荐阅读