如何使用外键扩展 IdentityUser

How to extend IdentityUser with a foreign key

我正在尝试使用外键 (BuildingID) 扩展 IdentityUser。下面是我的 ApplicationUser class,它派生自 IdentityUser class。添加外键的正确方法是什么?

public class ApplicationUser : IdentityUser
{
    public int BuildingID { get; set; }
}

我正在使用 Entity Framework Core

提前致谢

这是一个自以为是的答案。

当使用 ASP.NET Core Identity 时,根据我的经验,最好不要使用 IdentityUser,用于身份验证等目的。但是如果你的应用不是那个large/complex,我认为这个用户可以与其他实体建立关系。

在你的情况下,由于 BuildingApplicationUser 是一对一的关系,我建议不要将外键 属性 放在 ApplicationUser class。而是将其放在 Building class 中。这样,就不会在 AspNetUser table 中创建新列(即它会被单独保留),并且您将使 Building 成为依赖实体,而不是 ApplicationUser.因此,如果您要使用 Cascading 功能,删除 Building 不会删除相关的 ApplicationUser,而是相反。

public class ApplicationUser : IdentityUser
{
    public Building Building { get; set; }
}

public class Building
{
    public int Id { get; set; }
    public string Address { get; set; }
    public int ApplicationUserId { get; set; }
    
    public ApplicationUser ApplicationUser { get; set; }    
}

配置类似于 -

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    modelBuilder.Entity<Building>().ToTable("Building");
    modelBuilder.Entity<Building>(e =>
    {
        e.HasKey(p => p.Id);
        e.Property(p => p.Id).UseIdentityColumn<int>();     
        e.Property(p => p.Address).IsRequired(false).HasColumnType<string>("nvarchar(128)");
        e.Property(p => p.ApplicationUserId).IsRequired(true);
    });
    modelBuilder.Entity<Building>()
        .HasOne(e => e.ApplicationUser)
        .WithOne(p => p.Building)
        .HasForeignKey<Building>(e => e.ApplicationUserId)
        .OnDelete(DeleteBehavior.Cascade);
}

更新:

这是一对多方法

我将我的 ApplicationUser class 更改为以下内容:

public class ApplicationUser : IdentityUser
{
    public int BuildingID { get; set; }
    [ForeignKey("BuildingID")]
    public Building building { get; set; }
}

然后我通过包管理器控制台添加了一个迁移:

add-migration identity-user-extention

迁移完成后,我编辑了生成的代码并删除了所有创建和删除 table 的代码。这背后的原因是它试图重新创建我已经生成的所有 table。

public partial class identity-user-extention: Migration
{
    protected override void Up(MigrationBuilder migrationBuilder)
    {
        migrationBuilder.AddColumn<int>(
            name: "BuildingID",
            table: "AspNetUsers",
            nullable: false,
            defaultValue: 0);

        migrationBuilder.CreateIndex(
            name: "IX_AspNetUsers_BuildingID",
            table: "AspNetUsers",
            column: "BuildingID");

        migrationBuilder.AddForeignKey(
            name: "FK_AspNetUsers_BUILDING_BuildingID",
            table: "AspNetUsers",
            column: "BuildingID",
            principalTable: "BUILDING",
            principalColumn: "BUILDING_ID",
            onDelete: ReferentialAction.Cascade);
    }

    protected override void Down(MigrationBuilder migrationBuilder)
    {
        migrationBuilder.DropForeignKey(
            name: "FK_AspNetUsers_BUILDING_BuildingID",
            table: "AspNetUsers");

        migrationBuilder.DropIndex(
            name: "IX_AspNetUsers_BuildingID",
            table: "AspNetUsers");

        migrationBuilder.DropColumn(
            name: "BuildingID",
            table: "AspNetUsers");
    }
}

我保存了迁移,然后 运行 程序包管理器控制台中的以下内容:

Update-Database

然后我能够成功地创建一个帐户,并将 buildingID 作为外键(建筑物 table 已经填充)