如何使用外键扩展 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,我认为这个用户可以与其他实体建立关系。
在你的情况下,由于 Building
和 ApplicationUser
是一对一的关系,我建议不要将外键 属性 放在 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 已经填充)
我正在尝试使用外键 (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,我认为这个用户可以与其他实体建立关系。
在你的情况下,由于 Building
和 ApplicationUser
是一对一的关系,我建议不要将外键 属性 放在 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 已经填充)