实体框架多对多关系插入

本文关键字:插入 关系 实体 框架 | 更新日期: 2023-09-27 18:30:04

我有一个带有实体框架6的Web API应用程序。我有两个实体-玩家和比赛,它们之间有多对多的关系:

 public class Player {
    public string PlayerId { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public virtual ICollection<Match> Matches { get; set; }
}
 public class Match {
    public string MatchId { get; set; }
    public DateTime DateTime { get; set; }
    public virtual ICollection<Player> Players { get; set; }
}

这就是我的DBContext的样子:

public class FIFA15RankingContext : DbContext {
    public DbSet<Player> Players { get; set; }
    public DbSet<Match> Matches { get; set; }
    protected override void OnModelCreating(DbModelBuilder modelBuilder) {
        modelBuilder.Entity<Player>()
            .HasMany(t => t.Matches)
            .WithMany(t => t.Players)
            .Map(m => {
                m.ToTable("PlayerMatches");
                m.MapLeftKey("PlayerId");
                m.MapRightKey("MatchId");
            }
            );
        base.OnModelCreating(modelBuilder);
    }
}   

EF在幕后为我创建了PlayerMatches(PlayerId,MatchId)表。

这是我的MatchesController(由VS 2013搭建):

    // POST: api/Matches
    [ResponseType(typeof(Match))]
    public async Task<IHttpActionResult> PostMatch(Match match)
    {
        if (!ModelState.IsValid)
           return BadRequest(ModelState);
        db.Matches.Add(match);
        try
        {
            await db.SaveChangesAsync();
        }
        catch (DbUpdateException)
        {
            if (MatchExists(match.MatchId))
               return Conflict();
            else
               throw;               
        }
        return CreatedAtRoute("DefaultApi", new { id = match.MatchId }, match);
    }

我希望能够创建新的匹配并与现有用户关联。我无法以任何其他方式使它工作,只能在db之前添加这段代码(闻起来很难闻)。匹配。添加(匹配):

        var playersFromDB = new List<Player>();
        if (match.Players != null) {
            foreach (var p in match.Players) {
                playersFromDB.Add(db.Players.Find(p.PlayerId));
            }
        }
        match.Players = playersFromDB;

我做错了什么?

实体框架多对多关系插入

如果数据库中已经存在所有播放器,您可以将它们附加到dbcontext,而不是从db加载。

    if (match.Players != null) {
        foreach (var player in match.Players) {
            db.Players.Attach(player);
        }
    }

手动连接User实体并将其状态设置为Unchanged

foreach( var p in match.Players )
{
    db.Entry( p ).State = EntityState.Unchanged;
}