簡體   English   中英

外鍵在遷移時變得唯一

[英]Foreign Key becomes unique while migrating

這是主要的雇員表實體,而遷移外鍵變得唯一,並且不允許表中有重復值。

我需要在exitdetail實體中為單個雇員添加多個數據,因此我正在創建從雇員表到ExitDetailEntity表的外鍵引用,但是外鍵在遷移時成為唯一鍵,並且不允許重復。

public class EmployeeDetailEntity : Entity
{
    [Required]
    [StringLength(12)]
    public string EmployeeId { get; set; }

    [Required]
    [StringLength(64)]
    public string FirstName { get; set; }

    [StringLength(64)]
    public string MiddleName { get; set; }

    [StringLength(256)]
    public string FullName { get; set; }

    [StringLength(64)]
    public string LastName { get; set; }
}

該表具有EmployeeDetail的外鍵引用

public class ExitDetailEntity : Entity
{
    public int EmployeeDetailId {get; set; }
    public EmployeeDetailEntity EmployeeDetail {get; set; }

    public ExitStatusEnum ExitStatus {get; set;}
}

該表具有ExitDetil表的引用

public class ExitDetailAdminEntity : Entity
{
    public int ExitDetailId {get; set; }
    public ExitDetailEntity ExitDetail {get; set; }

    public bool HasTaskCompleted {get; set;}
}

這是exitdetail中引用的枚舉

public enum ExitStatusEnum
{
   Active = 0,
   Resigned = 1,
   Requested = 2,
   Cancelled = 3

}

這是exitdetailentity表的遷移命令

migrationBuilder.CreateTable(
            name: "ExitDetail",
            columns: table => new
            {
                Id = table.Column<int>(nullable: false)
                    .Annotation("SqlServer:ValueGenerationStrategy", SqlServerValueGenerationStrategy.IdentityColumn),
                CreatedBy = table.Column<string>(maxLength: 32, nullable: false),
                CreatedAt = table.Column<DateTime>(nullable: false),
                ModifiedBy = table.Column<string>(maxLength: 32, nullable: true),
                ModifiedAt = table.Column<DateTime>(nullable: true),
                RowVersion = table.Column<byte[]>(rowVersion: true, nullable: true),
                IsDeleted = table.Column<bool>(nullable: false),
                EmployeeDetailId = table.Column<int>(nullable: false),
                RequestStatus = table.Column<int>(nullable: false),
                ApprovalStatus = table.Column<int>(nullable: false)
            },
            constraints: table =>
            {
                table.PrimaryKey("PK_ExitDetail", x => x.Id);
                table.ForeignKey(
                    name: "FK_ExitDetail_EmployeeDetail_EmployeeDetailId",
                    column: x => x.EmployeeDetailId,
                    principalTable: "EmployeeDetail",
                    principalColumn: "Id",
                    onDelete: ReferentialAction.Cascade);
            });

這是唯一索引變為真的行

 migrationBuilder.CreateIndex(
            name: "IX_ExitDetail_EmployeeDetailId",
            table: "ExitDetail",
            column: "EmployeeDetailId",
            unique: true);

這是我的onmodelcreating方法中的代碼

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<LocationCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<OfficeCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<DivisionCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<RoleCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<TeamCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<FunctionCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<DesignationCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<LevelCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<ShiftCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<RegularizationTypeCodeTable>().HasQueryFilter(x => !x.IsDeleted);
        modelBuilder.Entity<EmployeeDetailEntity>().HasQueryFilter(x => !x.IsDeleted);

        modelBuilder
            .Entity<EmployeeDetailEntity>()
            .HasOne(x => x.ManagerRef)
            .WithMany()
            .OnDelete(DeleteBehavior.Restrict);

        modelBuilder
            .Entity<EmployeeDetailEntity>()
            .HasIndex(x => x.EmployeeId)
            .IsUnique();

        modelBuilder
           .Entity<EmployeeDetailEntity>()
           .HasIndex(x => x.DomainName);
    }

您需要為每個相關實體定義一個主鍵,例如:

public class ExitDetailEntity : Entity
{
    public int Id {get; set; } //primary key
    public int EmployeeDetailId {get; set; }
    public EmployeeDetailEntity EmployeeDetail {get; set; }
    public ExitStatusEnum ExitStatus {get; set;}
}

那么所有其他屬性將不是唯一的。

您可以看到: https : //docs.microsoft.com/en-us/ef/core/modeling/keys

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM