The INSERT statement conflicted with the FOREIGN KEY constraint “FK_PostTag_Tag_TagId”

后端 未结 2 2016
余生分开走
余生分开走 2021-01-07 13:28

I am using Entity Framework 7 RC1 and I have the entities:

public class Post {
  public Int32 Id { get; set; }
  public String Title { get;          


        
相关标签:
2条回答
  • 2021-01-07 13:53

    I had the same problems. Here's the solution I came up with. This SO question helped me a lot.

    First of all, add a public DbSet<Tag> Tags {get; set;} to yout Context class if it's missing.

    Then modify the post creation as follows

    Context context = new Context();
    var tmpTag = new Tag { Name = "Tag name" } //add the tag to the context
    context.Tags.Add(tmpTag);
    
    Post post = new Post {
        PostsTags = new List<PostTag>(), // initialize the PostTag list
        Title = "Post title"
    };    
    context.Posts.Add(post);
    
    var postTag = new PostTag() {Post = post, Tag = tag}; // explicitly initialize the PostTag AFTER addig both Post and Tag to context
    post.PostTags.Add(postTag); // add PostTag to Post
    
    await _context.SaveChangesAsync();
    

    Explictly adding both post and tag to context.Posts and context.Tags before attempting to create the PostTag object allows EF to correctly manage the IDs while writing to the underlying DB.

    For the sake of completeness, after solving this part of the many-to-many relationship management, I'm currently struggling with CascadeDelete Entity Framework Core (EF7), but that's a different story.

    0 讨论(0)
  • 2021-01-07 14:06

    I would say that you don't need to explicitly declare your foreign keys in EF CodeFirst the framework will handle it for you. So remove these properties from the PostTag class

    public Int32 PostId { get; set; }
    public Int32 TagId { get; set; }
    

    And then remove these two lines from your configuration then try the save again. You will probably need to update your DB Model before saving.

    b.HasKey(x => new { x.PostId, x.TagId });
    b.HasOne(x => x.Post).WithMany(x => x.PostsTags).HasForeignKey(x => x.PostId);
    b.HasOne(x => x.Tag).WithMany(x => x.PostsTags).HasForeignKey(x => x.TagId);
    
    0 讨论(0)
提交回复
热议问题