2

我们有一个继承自 IdentityUser 的 ApplicationUser 类。一个 ApplicationUser 可以有许多设备。

    public class ApplicationUser : IdentityUser
{
    public virtual ICollection<Device> Devices { get; set; }
}

设备定义为

    public partial class Device
{
    [Key]
    public int DeviceID { get; set; }
    public string UserId { get; set; }
    public virtual ApplicationUser User { get; set; }
    public string DeviceName { get; set; }
}

一对多关系设置在

protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);

            modelBuilder.Entity<Device>(entity =>
        {
            entity.HasKey(e => e.DeviceID);

            entity.Property(e => e.DeviceName)
                .IsRequired()
                .HasMaxLength(50)
                .HasColumnType("varchar");

            entity.Property(e => e.UserId)
                .IsRequired()
                .HasMaxLength(450);

            entity.HasOne(d => d.User).WithMany(p => p.Devices).HasForeignKey(d => d.UserId).OnDelete(DeleteBehavior.Restrict);
        });

        public virtual DbSet<Device> Devices { get; set; }
}

以下代码正确返回用户

var membershipUser = await _userManager.FindByEmailAsync(email);

我知道membershipUser 在Devices 表中有6 个设备,但是Devices 属性为空。

以下还为此用户设备返回 null

var deviceList = membershipUser.Devices.ToList();

如何连接设备以便正确返回?

4

1 回答 1

3

延迟加载对EF7. 但是您可以Include在您的请求中使用。

于 2016-01-04T07:50:18.620 回答