gpt4 book ai didi

c# - EF IsModified = false 仍在更新底层列

转载 作者:行者123 更新时间:2023-12-04 18:01:51 25 4
gpt4 key购买 nike

我有一个处于分离状态的实体。实体上有 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;
}

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

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

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

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

最佳答案

翻转语句的位置:

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;
}

因为你设置了 IsModified在设置对象的状态之前,每个属性都设置为 IsModified = true .

关于c# - EF IsModified = false 仍在更新底层列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34001808/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com