Entity Framework 4.3 code first multiple many to many using the same tables

前端 未结 1 714
猫巷女王i
猫巷女王i 2021-01-31 16:43

I have a model like

public class User
{
    [Key]
    public long UserId { get; set; }

    [Required]
    public String Nickname { get; set; }

    public virtu         


        
相关标签:
1条回答
  • 2021-01-31 17:03

    Well, EF doesn't have some kind of word and grammar recognition algorithm which would be required to identify that you (probably) want that User.Residencies and Town.Residents form a pair of navigation properties and User.Mayorships and Town.Mayors form a second pair. Therefore it assumes that you have four one-to-many relationships and that each of the four navigation properties belongs to one of the relationships. (This is the reason for the four foreign keys you have seen in the database tables.)

    This standard assumption is not what you want, hence you must define the relationships explicitly to override this standard convention:

    Either with data annotations:

    public class User
    {
        [Key]
        public long UserId { get; set; }
    
        [Required]
        public String Nickname { get; set; }
    
        [InverseProperty("Residents")]
        public virtual ICollection<Town> Residencies { get; set; }
    
        [InverseProperty("Mayors")]
        public virtual ICollection<Town> Mayorships { get; set; }
    }
    

    Or with Fluent API:

    modelBuilder.Entity<User>()
        .HasMany(u => u.Residencies)
        .WithMany(t => t.Residents)
        .Map(x =>
        {
            x.MapLeftKey("UserId");
            x.MapRightKey("TownId");
            x.ToTable("TownResidents");
        });
    
    modelBuilder.Entity<User>()
        .HasMany(u => u.Mayorships)
        .WithMany(t => t.Mayors)
        .Map(x =>
        {
            x.MapLeftKey("UserId");
            x.MapRightKey("TownId");
            x.ToTable("TownMayors");
        });
    

    Fluent API has the advantage that you can control the name of the link table (and the key column names as well). You cannot define those names with data annotations.

    0 讨论(0)
提交回复
热议问题