如何在EF CF中更新实体对象(分离)?

时间:2011-04-04 07:14:17

标签: c# entity-framework ef-code-first detach

我找到了解决方案:

MyEntity tmp = ctx.Entities.Where<MyEntity>(t => t.Id == objectWithNewValues.Id).SingleOrDefault();
if (tmp != null)
{
    var entityInDb = ctx.Entry(tmp);
    entityInDb.CurrentValues.SetValues(objectWithNewValues);
    ctx.SaveChanges();
}
else
{
    throw new ArgumentException ...
}

在我使用EF4之前,从架构生成代码,上下文将有一个方法 “context.ApplyCurrentValue(实体)”

当我尝试更新分离对象时,我可以这样做:

void UpdateObject(Entity e)
{    
     Entity tmp = ctx.Entities.Where(t=>t.id ==e.id);
     ctx.ApplyCurrentValue(e);
     ctx.SaveChannges();
}

现在我有一个使用EF4代码第一种方法的项目,我找不到“ApplyCurrentValue”方法了。

那么如何进行更新操作呢?

实体类是一个非常简单的类

public class MyEntity
{
    [Key]
    public Guid Id {get;set;}
    ...
}

我的上下文也是一个非常简单的类DBContext

public MyContext : DBContext
{
    public DBSet<MyEntity> Entities {get;set}

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Conventions.Remove<IncludeMetadataConvention>();
        modelBuilder.Entity<MyEntity>().ToTable("tblMyEntity");
    }
}

我正在尝试做以下事情。但价值没有更新到数据库!

ctx.entities.Attach(entity);
var entityInDb = ctx.Entry(entity);
entityInDb.CurrentValues.SetValues(entity);
context.SaveChanges();

我该如何进行更新?

3 个答案:

答案 0 :(得分:6)

迟到的回复,但我认为这会对社区有所帮助。 将您的更新方法更改为此

ctx.entities.Attach(entity);
var entry= ctx.Entry(entity);
entry.State = EntityState.Modified;
ctx.SaveChanges();

答案 1 :(得分:0)

ApplyChanges方法可能就是您所追求的目标:

model.ApplyChanges("Objects", object);
model.SaveChanges();
object.AcceptChanges();

注意:我们在EF4服务中使用自我跟踪实体T4模板

答案 2 :(得分:0)

也许Attach方法会有帮助吗?有关详细信息,请查看this article

void UpdateObject(Entity e) {
  Entity tmp = ctx.Entities.Attach(e);
  ctx.SaveChannges();
}