我有这个模型
public class Propiedad
{
[Key]
public int Id { get; set; }
public virtual Entidad Entidad { get; set; }
public virtual PestanasPorEntidad Pestana { get; set; }
public virtual GrupoDePropiedades Grupo { get; set; }
public string Codigo { get; set; }
public string Nombre { get; set; }
public string TipoDeDatos { get; set; }
public bool Requerido { get; set; }
[Required]
public int Orden { get; set; }
public string Columna { get; set; }
}
在编辑视图中,我有一个Grupo属性的下拉列表,如果我选择另一个值,这在数据库中不会改变并保持旧值
视图的一部分(编辑)
<div class="form-group">
@Html.LabelFor(model => model.Grupo, new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownListFor(m => m.Grupo.Id, (SelectList)(ViewBag.GrupoList), "Seleccionar", new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.Grupo)
</div>
</div>
这是编辑方法
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Edit([Bind(Include = "Id,Codigo,Nombre,TipoDeDatos,Requerido,Columna,Grupo")] Propiedad propiedad)
{
if (ModelState.IsValid)
{
var grupo = unitOfWork.GrupoDePropiedadesRepository.GetById(propiedad.Grupo.Id);
propiedad.Grupo = grupo;
unitOfWork.PropiedadRepository.Update(propiedad);
unitOfWork.Save();
return RedirectToAction("Index", new { entidadId = Request["entidadId"] });
}
return View(propiedad);
}
这是GenericRepository的更新
public void Update(TEntity entityToUpdate)
{
_dbSet.Attach(entityToUpdate);
_context.Entry(entityToUpdate).State = EntityState.Modified;
}
我做错了什么?
答案 0 :(得分:1)
我建议您在编辑操作中从数据库整个实体Grupo
中检索。
然后尝试做这样的事情:
var groupoEntity = unitOfWork.GrupoDePropiedadesRepository.GetById(propiedad.Grupo.Id);
接下来,您可以将更新从groupo
转移到groupoEntity
。例如:
groupoEntity.PropA = grupo.PropA;
groupoEntity.SomeId = grupo.SomeId;
unitOfWork.GrupoDePropiedadesRepository.Update(groupoEntity);
unitOfWork.Save();