jperez
jperez

Reputation: 1060

TryUpdateModel / UpdateModel does not work?

I'm trying to update multiple objects that exist in database and save new objects, but it doesnt work?

Here is my code:

    [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");
        }
    }

if after TryUpdateModel I do db.SaveChanges(); i get a System.Data.UpdateException with referential integrity

And if I let my code like in the example it just doesn't update! :S

Oh yeah, I've also tried UpdateModel() instead.

Any suggestions?

Thanks in advance!

Cheers

Upvotes: 1

Views: 762

Answers (1)

ADIMO
ADIMO

Reputation: 1117

The usual workflow for update an object is:

1) Load old object (using id) 2) Change properties 3) SaveChanges

Upvotes: 0

Related Questions