entity-framework – 如何告诉UserManager.FindByNameAsync包含关系?

我使用ASP.NET Identity 2.2.0与ASP.NET MVC 5.2.3和Entity Framework 6.1.2.

我使用带有Code First的ASP.NET Identity将一个属性及其相应的表添加到我的数据库中,如下所示:

public class ApplicationUser
{
  [ForeignKey("UserTypeId")]
  public UserType Type { get; set;}
  public int UserTypeId { get; set;} 
}

public class UserType
{
  [Key]
  public int Id { get; set;}

  public string Name { get; set; }
}

现在,从某些动作开始,当我打电话时:

var user = UserManager.FindByNameAsync(userName);

它确实为用户提供了正确的UserTypeId,因为它是一个原语,但它不会获得ApplicationUser类的UserType属性.

如果我没有使用这种抽象,我会调用LoadProperty< T>或实体框架中的Include方法,以在ApplicationUser类中包含名为Type(类型为UserType)的导航属性或关系.

如何使用ASP.NET Identity的UserManager执行此操作?我怀疑唯一的方法是在我的自定义UserManager派生类中重写此方法并自己执行此操作?

解决方法

使用实体框架延迟加载,您需要确保将导航属性标记为虚拟.

public class ApplicationUser
{
    [ForeignKey("UserTypeId")]
    public virtual UserType Type { get; set;}
    public int UserTypeId { get; set;} 
}

或者,如果您不能/不想使用延迟加载,那么您仍然可以像使用任何其他实体一样使用您的上下文:

var user = context.Users.Include(u => u.Type).Single(u => u.UserName == userName);

相关文章

### 创建一个gRPC服务项目(grpc服务端)和一个 webapi项目(...
一、SiganlR 使用的协议类型 1.websocket即时通讯协议 2.Ser...
.Net 6 WebApi 项目 在Linux系统上 打包成Docker镜像,发布为...
一、 PD简介PowerDesigner 是一个集所有现代建模技术于一身的...
一、存储过程 存储过程就像数据库中运行的方法(函数) 优点:...
一、Ueditor的下载 1、百度编辑器下载地址:http://ueditor....