Entity Framework 5.多対多の関係を更新すると、主キーの違反が発生する

私はこのような多くの質問を見たことがありますが、それらの人々は私がしていない多対多の関係のメソッドを追加しています。私はWebApiを使用しています

.Clear()を呼び出して、エンティティフレームワーク5の更新されたエンティティを再度追加すると仮定するか、それとも自動的に何か間違っていますか?

私はUnit of Workと一般的なEntity Framework Repositoryパターンを使用しています。

これは関連するコードです:

 public HttpResponseMessage Put(PromDto promDto)
{
    var creditCardsIds = string.IsNullOrEmpty(promDto.CreditCards) ? null : promDto.CreditCards.Split(',').Select(int.Parse);
    var branchesIds = string.IsNullOrEmpty(promDto.Branches) ? null : promDto.Branches.Split(',').Select(int.Parse);

    var promotion = Uow.Promotions.GetById(promDto.Id);

    promotion.CreditCards = creditCardsIds != null ? Uow.CreditCards.GetByPredicate(t => creditCardsIds.Contains(t.Id)).ToList() : null;
    promotion.Branches = branchesIds != null ? Uow.Branches.GetByPredicate(t => branchesIds.Contains(t.Id)).ToList() : null;

    if (ModelState.IsValid)
    {
        Uow.Promotions.Update(promotion);
        Uow.Commit();
        return new HttpResponseMessage(HttpStatusCode.NoContent);
    }

    throw new HttpResponseException(HttpStatusCode.BadRequest);
}

コンテキスト内

modelBuilder.Entity().
    HasMany(p => p.Promotions).
    WithMany(s => s.Branches).
    Map(
    m =>
    {
      m.MapLeftKey("BranchId");
      m.MapRightKey("PromotionId");
      m.ToTable("Branch_Promotion");
    });

modelBuilder.Entity().
    HasMany(tt => tt.CreditCards).
    WithMany(p => p.Promotions).
    Map(
    m =>
    {
     m.MapLeftKey("PromotionId");
     m.MapRightKey("CreditCardId");
     m.ToTable("Promotion_CreditCard");
    });

私はこれを呼び出すと思いますか?

promocion.CreditCards.Clear();
promocion.Branches.Clear();

前もって感謝します。ギレルモ。

0
nl ru de

2 答え

これを追加すると解決されます:

var promotion = Uow.Promotions.GetByPredicateIncluding(p => p.Id == promotionDto.Id, a => a.CreditCards, a => a.Branches).ToList().FirstOrDefault();

関連するエンティティをロードします。

Entity Frameworkが新しいものかどうかを知るためには、それらをロードする必要があるようです。

誰かがより良い説明をしている場合は、自由にコメントを追加してください。

宜しくお願いします。ギレルモ。

0
追加された

これを追加すると解決されます:

var promotion = Uow.Promotions.GetByPredicateIncluding(p => p.Id == promotionDto.Id, a => a.CreditCards, a => a.Branches).ToList().FirstOrDefault();

関連するエンティティをロードします。

Entity Frameworkが新しいものかどうかを知るためには、それらをロードする必要があるようです。

誰かがより良い説明をしている場合は、自由にコメントを追加してください。

宜しくお願いします。ギレルモ。

0
追加された