在数据库中编辑对象之前,如何获取对象的值?



我正在编写一个Web API 2的Web服务,并希望在DbSet中编辑对象之前获得对象的值。

我已经做了一些研究,我相信我需要使用ObjectStateEntry对象。但是,我不确定如何使用ObjectStateEntry对象获取对象的值。

这是一个简单的 put 函数,其中包含一些我认为应该可以工作的代码:

// PUT: api/Templates1/5
[ResponseType(typeof(void))]
public async Task<IHttpActionResult> PutTemplate(int id, Template template)
{
    if (!ModelState.IsValid)
    {
        return BadRequest(ModelState);
    }
    if (id != template.id)
    {
        return BadRequest();
    }
    ObjectStateEntry myObjectState = db.ObjectStateManager.GetObjectStateEntry(template);
    var originalValues = myObjectState.OriginalValues;
    db.Entry(template).State = EntityState.Modified;
    try
    {
        await db.SaveChangesAsync();
    }
    catch (DbUpdateConcurrencyException)
    {
        if (!TemplateExists(id))
        {
            return NotFound();
        }
        else
        {
            throw;
        }
    }
    return StatusCode(HttpStatusCode.NoContent);
}

我收到以下错误:

"DataService.Context.DataServiceContext"不包含定义 对于"ObjectStateManager",没有扩展方法"ObjectStateManager" 接受类型的第一个参数 可以找到"DataService.Context.DataServiceContext"(你是 缺少 using 指令或程序集引用?

在数据库中编辑对象之前,有人可以帮我获取对象的值吗?

ObjectStateManager 是 ObjectContext 中的一个属性

using (var ctx = new TestContext())
{
    var first = ctx.Entity_Basics.First();
    var objectStateEntry = ((IObjectContextAdapter)ctx).ObjectContext.ObjectStateManager.GetObjectStateEntry(first);

    //ctx.Entity_Basics.Delete();
    //ctx.Entity_Basics.Update(x => new Entity_Basic() { ColumnInt = 2 });
}

如果您需要更多帮助,可以查看我的 EntityFramework Plus Audit 库的源代码

相关内容

  • 没有找到相关文章

最新更新