0

このような質問をたくさん見てきましたが、それらの人々は多対多の関係で .Add メソッドを呼び出していましたが、私はそうではありません。私は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<Branch>().
    HasMany(p => p.Promotions).
    WithMany(s => s.Branches).
    Map(
    m =>
    {
      m.MapLeftKey("BranchId");
      m.MapRightKey("PromotionId");
      m.ToTable("Branch_Promotion");
    });

modelBuilder.Entity<Promotion>().
    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();

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

4

1 に答える 1

0

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

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

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

Entity Frameworkが新しいかどうかを知るためにロードする必要があるようです。

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

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

于 2013-01-29T02:55:09.123 に答える