c# – AutoMapper将2个表中的记录连接到单个IEnumerable视图模型中

我有2个表,比如T1和T2. T1包含oID,cID,日期,状态,T2包含cID,cName,cURL.我为以上2个表设计了类,如下所示:

T1.cs

public class T1{
  public int oID{get;set;}
  public int cID{get;set;}
  public DateTime date{get;set;}
  public string status{get;set;}
}

T2.cs

public class T2{
    public int cID{get;set;}
    public string cName{get;set;}
    public string cURL{get;set;}

}

T1中的cID是引用T2-cID的外键

现在我有我的T3视图模型,如下所示,结合T1和T2

T3.cs

public class T3:T1
{
   public int cID{get;set;}
   public string cName{get;set;}
   public string cURL{get;set;}
}

T3扩展T1和T2属性在T3中定义.因此,我打算使用AutoMapper在单个视图模型中组合2个表.我有以下方法从T1获取T1的所有细节和T2的相关细节,填充后将返回IEnumerable T3.

public IEnumerable<T3> GetAll()
{
   var od = mycontext.t1repository.GetMany().ToList();
   var ck = myContext.t2repository.GetMany(x => od.All(y => y.cID == x.cID)).ToList();
   if (od.Any())
   {
        Mapper.CreateMap<tblT1, T3>();
        Mapper.CreateMap<tblT2, T3>()
                    .ForMember(x=>x.cID, a => a.MapFrom(s => s.cID))
        var response = Mapper.Map<List<T1>, List<T3>>(od);
        return response;
   }
   return null;
}

我通过this answer尝试了上面的代码,但这是针对单个实例的,我必须返回IEnumerable记录.我不确定如何基于他们的cID从2表中实际映射数据.知道我怎么能做到这一点?

解决方法:

我想你可以尝试这样的事情:

var config = new MapperConfiguration(cfg =>
{
    cfg.CreateMap<T1, T3>();
    cfg.CreateMap<T2, T3>();
});

var mapper = config.CreateMapper();

var od = new List<T1> { ... };
var ck = new List<T2> { ... };

var result = od.Join(ck, t => t.cID, t => t.cID, (t1, t2) =>
{
    var t3 = mapper.Map<T1, T3>(t1);
    t3 = mapper.Map<T2, T3>(t2, t3);

    return t3;
});
上一篇:c# – Automapper – ReverseMap()不执行映射


下一篇:c# – AutoMapper MaxDepth()方法