我们有一个继承自 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();
如何连接设备以便正确返回?