5

我找到了解决方案:

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(entity)”

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

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();

我该如何进行更新?

4

3 回答 3

6

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

ctx.entities.Attach(entity);
var entry= ctx.Entry(entity);
entry.State = EntityState.Modified;
ctx.SaveChanges();
于 2012-04-28T21:38:39.347 回答
0

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

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

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

于 2011-04-04T07:20:15.063 回答
0

也许 Attach 方法会有所帮助?看看这篇文章了解更多信息。

void UpdateObject(Entity e) {
  Entity tmp = ctx.Entities.Attach(e);
  ctx.SaveChannges();
}
于 2011-04-04T08:30:18.117 回答