Entity Manager - Обновление ссылочного идентификатора моей модели
У меня есть Tablo
объект, который имеет ссылку на Ressam
объект. В моем действии Изменить для Tablo
Я хочу иметь возможность изменить Ressam
ссылка тоже, то есть ссылка на другой RessamId
, Вот код контроллера, скажем, я хочу только изменить Ressam
из Tablo
в моем звонке:
[HttpPost]
public ActionResult EditTablo(Tablo tablo, int? RessamId, HttpPostedFileBase image)
{
// Here, I successfully get RessamId, no problem there
if (ModelState.IsValid)
{
// this is where I attach the Tablo object
if (tablo is TuvalBaski)
{
container.Urun.Attach((TuvalBaski)tablo);
}
else if (tablo is YagliBoya)
{
container.Urun.Attach((YagliBoya)tablo);
}
// and this is the part where I change the Ressam reference
if (RessamId == null)
{
tablo.Ressam = null;
container.Ressam.Attach(tablo.Ressam);
TryUpdateModel(tablo.Ressam);
}
else
{
tablo.Ressam = (from table in container.Ressam
where table.RessamId == RessamId
select table).Single();
//container.Ressam.Context.ObjectStateManager.ChangeObjectState(tablo.Ressam, System.Data.EntityState.Modified);
//container.ObjectStateManager.ChangeObjectState(tablo.Ressam, System.Data.EntityState.Modified);
container.Ressam.Attach(tablo.Ressam);
TryUpdateModel(tablo.Ressam);
}
return View(tablo);
}
Кстати, это не работает. Как я могу обновить ссылочный идентификатор в моем Tablo
сущность, чтобы она могла показать другую Ressam
?
2 ответа
Решение
Без лишних разговоров вот код, который делает эту работу:
[HttpPost]
public ActionResult EditTablo(Tablo tablo, int? RessamId, HttpPostedFileBase image)
{
if (ModelState.IsValid)
{
if (tablo is TuvalBaski)
{
container.Urun.Attach((TuvalBaski)tablo);
}
else if (tablo is YagliBoya)
{
container.Urun.Attach((YagliBoya)tablo);
}
if (RessamId == null)
{
if(tablo.Ressam != null)
{
container.Ressam.Detach(tablo.Ressam);
}
tablo.Ressam = null;
}
else
{
if (tablo.Ressam != null)
{
container.Ressam.Detach(tablo.Ressam);
}
tablo.Ressam = (from table in container.Ressam
where table.RessamId == RessamId
select table).Single();
container.Ressam.Attach(tablo.Ressam);
}
TryUpdateModel(tablo);
container.SaveChanges();
}
return View(tablo);
}
Вы должны приложить tablo
экземпляр в контексте.
[HttpPost]
public ActionResult EditTablo(Tablo tablo, int? RessamId, HttpPostedFileBase image)
{
if (ModelState.IsValid)
{
container.Tablo.Attach(tablo);
container.ObjectStateManager
.ChangeObjectState(tablo, System.Data.EntityState.Modified);
if (RessamId != null)
{
tablo.Ressam = (from table in container.Ressam
where table.RessamId == RessamId
select table).Single();
TryUpdateModel(tablo.Ressam);
}
container.SaveChanges();
}
return View(tablo);
}