EF 핵심 오류의 자체 참조 : 삽입 문이 외래 키 동일한 테이블 제약 조건과 충돌했습니다.

Aug 18 2020

Category자체 참조 가있는 모델 이 있고 데이터베이스를 만드는 데 잘 작동했지만 부모 범주 (parentId가없는 엔터티)를 삽입하려고하면 외래 키 "ParentId"를 가리키는 오류가 발생하지만 삽입하면 제대로 작동합니다. SSMS의 삽입 스크립트를 사용하여 수동으로 topel하고 하위 범주 (parentId가있는 엔터티)를 추가 할 때 ef core와 잘 작동합니다.

카테고리 모델

public class Category : ICategory
{
    public Category()
    {
    }

    [Key]
    public int Id { get; set; }

    [Required]
    [MinLength(2)]
    [MaxLength(32)]
    public string Title { get; set; }

    public string Icon { get; set; }

    [DefaultValue(true)]
    public bool IsEnabled { get; set; }

    [Required]
    public DateTime CreateTimeStamp { get; set; }

    public DateTime LastUpdateTimeStamp { get; set; }

    [ForeignKey("User")]
    public int CreatorUserId { get; set; }
    
    public int? ParentId { get; set; }

    public virtual User User { get; set; }
    
    [ForeignKey("ParentId")]
    public virtual Category Parent { get; set; }
    public virtual ICollection<Category> Children { get; set; }
    public virtual ICollection<Service> Services { get; set; }
}

DBContext

public DbSet<Category> Categories { get; set; }

modelBuilder.Entity<Category>(entity =>
        {
            entity.HasIndex(e => e.Title).IsUnique();
            entity.HasOne(e => e.User).WithMany(e => e.CreatedCategories)
                .HasForeignKey(e => e.CreatorUserId).OnDelete(DeleteBehavior.Restrict);
            entity.HasOne(e => e.Parent).WithMany(e => e.Children).HasForeignKey(e => e.ParentId).IsRequired(false);
        });

이주

protected override void Up(MigrationBuilder migrationBuilder)
{
        migrationBuilder.CreateTable(
            name: "Categories",
            columns: table => new
            {
                Id = table.Column<int>(nullable: false)
                    .Annotation("SqlServer:Identity", "1, 1"),
                Title = table.Column<string>(maxLength: 32, nullable: false),
                Photo = table.Column<string>(nullable: true),
                IsEnabled = table.Column<bool>(nullable: false),
                CreateTimeStamp = table.Column<DateTime>(nullable: false),
                LastUpdateTimeStamp = table.Column<DateTime>(nullable: false),
                CreatorUserId = table.Column<int>(nullable: false),
                ParentId = table.Column<int>(nullable: true)
            }
            constraints: table =>
            {
                table.PrimaryKey("PK_Categories", x => x.Id);
                table.ForeignKey(
                    name: "FK_Categories_Users_CreatorUserId",
                    column: x => x.CreatorUserId,
                    principalTable: "Users",
                    principalColumn: "Id",
                    onDelete: ReferentialAction.Restrict);
                table.ForeignKey(
                    name: "FK_Categories_Categories_ParentId",
                    column: x => x.ParentId,
                    principalTable: "Categories",
                    principalColumn: "Id",
                    onDelete: ReferentialAction.Restrict);
            });
}

어쨌든 "ParentId"를 nullable로 표시했습니다. SQL Server는 괜찮지 만 ef core가 나를 막고 있습니다!

오류 메시지 내부 예외 :

INSERT 문이 FOREIGN KEY SAME TABLE 제약 조건 "FK_Categories_Categories_ParentId"와 충돌했습니다. "Unknown_Db"데이터베이스, "dbo.Categories"테이블, 'Id'열에서 충돌이 발생했습니다.

답변

1 happykratos Aug 18 2020 at 00:38

입력 값을 처리하는 곳에서 시도해보십시오.

if (category.ParentId == 0)
{
    category.ParentId = null;
}