Ips*_*der 3 c# fluent automapper entity-framework-core asp.net-core
我的数据库中有两个实体。A 和 B。我还有一个关系表,表示这些实体 AB 之间的多对多关系:
public class A
{
public ICollection<AB> ABs { get; set; }
}
public class B
{
public ICollection<AB> ABs { get; set; }
}
public class AB
{
public A A { get; set; }
public B B { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
现在我想在我的 dto 中隐藏这个关系表,如下所示:
public class ADTO
{
public ICollection<B> Bs { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
我想要一个 B 的单个集合,其中我的实例直接表示,而不是作为关系表。我想要一个自动映射器配置文件,它从实体 B 列表映射到以前不存在的实体 AB 列表,其中 B 作为属性,以及实例 A 本身。
我已经实现了从 A 到 ADTO 的映射器,如下所示:
public class AProfile : Profile
{
public AProfile()
{
CreateMap<A, ADTO>()
.ForMember(dest => dest.B, opt => opt.MapFrom(src => src.AB.Select(y => y.B).ToList()));
CreateMap<ADTO, A>();
}
}
Run Code Online (Sandbox Code Playgroud)
我缺少的是相反的方向:从 ADTO 及其实体列表到 A 及其对关系表实体的引用。
让您的个人资料如下:
CreateMap<ADTO, A>()
.ForMember(dest => dest.AName, opt => opt.MapFrom(src => src.AName))
.ForMember(dest => dest.ABs, opt => opt.MapFrom(src => src.Bs))
.AfterMap((src, dest) =>{
foreach(var b in dest.ABs)
{
b.AId = src.Id;
}
});
CreateMap<B, AB>()
.ForMember(dest=>dest.BId,opt=>opt.MapFrom(src=>src.Id))
.ForMember(dest=>dest.B,opt=>opt.MapFrom(src=>src));
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4405 次 |
| 最近记录: |