EF IsModified = false 仍在更新基础列

gh9*_*gh9 5 c# entity-framework

我有一个处于分离状态的实体。实体上有 2 个字段我不想更新。我将其 IsModfied 设置为 false,但 SQL SERVER 中的属性仍在更新。如何强制这些列不更新 SQL SERVER?

if (Context.Entry(updatedFoo).State == EntityState.Detached)
{
   var oldEntity = Context.Foo.Find(updatedFoo.FooId);
   Context.Entry(oldEntity).Property(x => x.createdUserId).IsModified = false;
   Context.Entry(oldEntity).Property(x => x.createDateTime).IsModified = false;
   Context.Entry(oldEntity).CurrentValues.SetValues(updatedSaving);
   Context.Entry(oldEntity).State = EntityState.Modified;
}
Run Code Online (Sandbox Code Playgroud)

******编辑*****

将 EntityState 设置为“modified”会覆盖之前设置的所有属性级别状态。

如果您将状态设置为已修改,然后设置列上的各个属性,您将收到以下错误

附加信息:不支持将已修改属性的 IsModified 设置为 false

Loe*_*etn 4

翻转语句的位置:

if (Context.Entry(updatedFoo).State == EntityState.Detached)
{
   var oldEntity = Context.Foo.Find(updatedFoo.FooId);
   Context.Entry(oldEntity).CurrentValues.SetValues(updatedSaving);
   Context.Entry(oldEntity).State = EntityState.Modified;
   Context.Entry(oldEntity).Property(x => x.createdUserId).IsModified = false;
   Context.Entry(oldEntity).Property(x => x.createDateTime).IsModified = false;
}
Run Code Online (Sandbox Code Playgroud)

因为您IsModified在设置对象的状态之前进行设置,所以每个属性都设置为IsModified = true