实体框架更新删除记录

时间:2013-05-10 22:59:15

标签: asp.net-mvc-4 entity-framework-5 unit-of-work

我正在使用.Net4.5,EF5和MSSQL 2008R2开发MVC4应用程序。我正在使用Db Context和自动生成的实体类/模型和工作单元模式。

当我尝试通过Edit ActionResult方法更新表记录时,当我更新的数据最初为null时,记录将被删除,例如添加中间名称。

我可以将ActionResult中的对象跟随GenericRepository到UnitOfWork Save(),其中调用db context savechanges()。直到那时数据才存在。在那之后,我不确定如何调试它。

因此,任何有关调试或解决此问题的帮助都将受到赞赏。我可以成功创建和删除表记录。我还尝试使用相同的删除结果在Edit ActionResult中使用db上下文。我测试了映射的存储过程,它正确更新。

    [HttpPost]
    public ActionResult Edit(v_Demographics vm)
    {

        try
        {
            if (ModelState.IsValid)
            {
                unitOfWork.DemographicsRepository.Update(vm);
                unitOfWork.Save();
                //db.Entry(vm).State = EntityState.Modified;
                //db.SaveChanges();
                return RedirectToAction("Index");
            }
        }
        catch (DataException)
        {
            //Log the error (add a variable name after DataException)
            ModelState.AddModelError("", "Unable to save changes. Try again, and if the problem persists see your system administrator.");
        }
        return View(vm);
    }


public class GenericRepository<TEntity> where TEntity : class
   {
    internal SEntities db = new SEntities();
    internal DbSet<TEntity> dbSet;

    public GenericRepository(AIPIMSEntities db)
    {
        this.db = db;
        this.dbSet = db.Set<TEntity>();
    }

    public virtual void Update(TEntity entityToUpdate)
    {
        dbSet.Attach(entityToUpdate);
        db.Entry(entityToUpdate).State = EntityState.Modified;
    }
}


 public class UnitOfWork : IDisposable
{
    private AIPIMSEntities db = new AIPIMSEntities();
    private GenericRepository<v_Demographics> demographicsRepository;

    public GenericRepository<v_Demographics> DemographicsRepository
    {
        get
        {

            if (this.demographicsRepository == null)
            {
                this.demographicsRepository = new GenericRepository<v_Demographics>(db);
            }
            return demographicsRepository;
        }
    }


    public void Save()
    {
        db.SaveChanges();
    }

    private bool disposed = false;

    protected virtual void Dispose(bool disposing)
    {
        if (!this.disposed)
        {
            if (disposing)
            {
                db.Dispose();
            }
        }
        this.disposed = true;
    }

    public void Dispose()
    {
        Dispose(true);
        GC.SuppressFinalize(this);
    }
}

1 个答案:

答案 0 :(得分:0)

事实证明,删除错误是由MSSQL视图引起的。这里的代码基于此tutorial,现在非常有用。