[英]EF Core Many-to-Many Relationship Identity Insert Error
我已按照本指南在我的API中實現多對多關系https://www.learnentityframeworkcore.com/configuration/many-to-many-relationship-configuration
當我嘗試創建一個新的項目條目,其中包含地區名單(從預定義的列表中選擇)要保存到ProjectAreas鏈接表我收到以下錯誤: 無法為表“區”的身份列時插入顯式值IDENTITY_INSERT設置為OFF。
public class Project
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public long ProjectId { get; set; }
public string ProjectName { get; set; }
public string ProjectDescription { get; set; }
public DateTime StartDate { get; set; }
public DateTime EndDate { get; set; }
public DateTime CreateDate { get; set; }
public User CreatingUser { get; set; }
public bool Closed { get; set; }
public User ClosingUser { get; set; }
public DateTime CloseDate { get; set; }
public Customer Customer { get; set; }
public ICollection<ProjectArea> ProjectAreas { get; set; }
public ICollection<ProjectCategory> ProjectCategories { get; set; }
}
public class Area
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public long AreaId { get; set; }
public string AreaName { get; set; }
public string Description { get; set; }
public bool Active { get; set; }
public User CreatingUser { get; set; }
public Customer Customer { get; set; }
public ICollection<ProjectArea> ProjectAreas { get; set; }
}
public class ProjectArea
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public long ProjectAreaId { get; set; }
[ForeignKey("Project")]
public long ProjectId { get; set; }
public Project Project { get; set; }
[ForeignKey("Area")]
public long AreaId { get; set; }
public Area Area { get; set; }
}
public class DatabaseContext : DbContext
{
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<ProjectArea>().HasKey(projectArea => new { projectArea.ProjectId, projectArea.AreaId });
modelBuilder.Entity<ProjectArea>().HasOne(projectArea => projectArea.Project).WithMany(project => project.ProjectAreas).HasForeignKey(projectArea => projectArea.ProjectId);
modelBuilder.Entity<ProjectArea>().HasOne(projectArea => projectArea.Area).WithMany(area => area.ProjectAreas).HasForeignKey(projectArea => projectArea.AreaId);
}
public void Add(Project entity)
{
databaseContext.Project.Add(entity);
databaseContext.SaveChanges();
}
有人可以告訴我我想念什么嗎?
將您的OnModelCreating更改為此:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<ProjectArea>()
.HasKey(projectArea => new
{
projectArea.ProjectId,
projectArea.AreaId
});
modelBuilder.Entity<Project>()
.HasMany(c => c.ProjectArea)
.WithRequired()
.HasForeignKey(c => c.ProjectId);
modelBuilder.Entity<Area>()
.HasMany(c => c.ProjectArea)
.WithRequired()
.HasForeignKey(c => c.AreaId);
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.