相关疑难解决方法(0)

如何使用Entity Framework 6更新记录?

我正在尝试使用EF6更新记录.首先找到记录,如果存在,则更新它.这是我的代码: -

var book = new Model.Book
{
    BookNumber =  _book.BookNumber,
    BookName = _book.BookName,
    BookTitle = _book.BookTitle,
};
using (var db = new MyContextDB())
{
    var result = db.Books.SingleOrDefault(b => b.BookNumber == bookNumber);
    if (result != null)
    {
        try
        {
            db.Books.Attach(book);
            db.Entry(book).State = EntityState.Modified;
            db.SaveChanges();
        }
        catch (Exception ex)
        {
            throw;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

每次我尝试使用上面的代码更新记录时,我收到此错误: -

{System.Data.Entity.Infrastructure.DbUpdateConcurrencyException:存储更新,插入或删除语句影响了意外的行数(0).自实体加载后,实体可能已被修改或删除.刷新ObjectStateManager entrie

c# entity-framework ef-database-first entity-framework-6

227
推荐指数
10
解决办法
48万
查看次数