1

データベースに存在する複数のオブジェクトを更新して新しいオブジェクトを保存しようとしていますが、うまくいきませんか?

これが私のコードです:

    [HttpPost]
    public ActionResult Edit(MasterModel Model)
    {
        DBEntities db = new DBEntities();
        var reloadView = true;
        for(int i = 0 ;i< Model.Emails.Count(); i++)
        {
            if(Model.Emails[i].ID > 0 )
            {
                var id = Model.Emails[i].ID;
                var email = db.EMAIL.Single(e=> e.ID == id);
                if(TryValidateModel(Model.Emails[i], "Emails[" +i.ToString() + "]"))
                {
                    TryUpdateModel(email, "Emails[" + i.ToString() + "]");
                    reloadView = false;
                }
                else
                {
                    reloadView = true;
                }

            }
            else
            {
                if(TryValidateModel(Model.Emails[i], "Emails[" + i.ToString() + "]"))
                {
                    db.AddToEMAIL(Model.Emails[i]);
                    reloadView = false;
                }
                else
                {
                    reloadView = true;
                }
            }
        }

        if(reloadView)
        {
            return View(Model);
        }
        else
        {
            db.SaveChanges();
            return RedirectToAction("Index");
        }
    }

TryUpdateModel の後に db.SaveChanges(); を実行した場合 参照整合性を持つ System.Data.UpdateException を取得します

そして、コードを例のようにすると、更新されません! :S

そうそう、代わりに UpdateModel() も試しました。

助言がありますか?

前もって感謝します!

乾杯

4

1 に答える 1

0

オブジェクトを更新する通常のワークフローは次のとおりです。

1) 古いオブジェクトを読み込みます (id を使用) 2) プロパティを変更します 3) SaveChanges

于 2011-11-03T16:57:37.040 に答える