我找到了解决方案:
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();
我该如何进行更新?
答案 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();
}