繁体   English   中英

如何在实体框架中映射列表?

[英]How to map a List in Entity Framework?

我有两个类: RoleRoleViewModel

角色

public partial class Role
{
    public Role()
    {
        this.Users = new HashSet<User>();
    }

    public int RoleId { get; set; }
    public string Name { get; set; }
    public string Description { get; set; }

    public virtual ICollection<User> Users { get; set; }
}

RoleViewModel

public class RoleViewModel
{
    public RoleViewModel()
    {
        this.Users = new HashSet<UserViewModel>();
    }

    public int RoleId { get; set; }
    public string Name { get; set; }
    public string Description { get; set; }

    public virtual ICollection<UserViewModel> Users { get; set; }
}

现在,我试图从数据库中获取一个Role列表,并将其mapRoleViewModel列表。

 public static List<RoleViewModel> GetRolesService()
 {
     List<Role> roles =MainRepository.GetUserRoles();
     var rolesVM = Mapper.Map<List<Role>, List<RoleViewModel>>(roles);
     return rolesVM;
 }

问题在于rolesVM列表始终具有Count=0 ,我不知道为什么。

提前致谢!。

一种解决方案是忽略嵌套依赖性。

Mapper.CreateMap<Role, RoleViewModel>().ForMember(c=>c.Users,option=>option.Ignore());

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM