4

我有一种更新某些表的方法。对于更新,我需要先获取TestProcess,但我不喜欢那样。如何TestProcess不进行select(firstOrDefault)操作更新,仅用于更新操作?

方法示例:

public void UpdateTestProcess(int id, string updateID)
{
    using (TestEntities context = new TestEntities())
                {
                    TestProcess pr = context.TestProcess.FirstOrDefault(x => x.MyID == id);
                    pr.UpdateID = updateID;             

                    context.TestProcess.Attach(pr);
                    context.ObjectStateManager.ChangeObjectState(pr, EntityState.Modified);
                    context.SaveChanges();
               }
}
4

3 回答 3

7
TestProcess pr = new TestProcess()
{
    MyID == id,
};

context.Set<TestProcess>().Attach(pr);

pr.UpdateID = updateID;

context.SaveChanges();

如果您将值设置为该类型的默认值(例如,将 an 设置int0),则不会将其视为更改,您需要手动设置状态。

pr.UpdateID = updateID;
context.Entry(pr).Property(p => p.UpdateID).IsModified = true;

您可以将此类代码放在扩展方法中,因此您可以执行以下操作(我将把实现留作练习):

Foo entity = this.DbContext.GetEntityForUpdate<Foo>(
    item => item.ID, model.ID
    );

this.DbContext.UpdateProperty(entity, item => item.Name, model.Name);
于 2013-07-03T08:10:58.397 回答
2

您可以这样做(您可能应该拥有所有测试过程数据):

TestProcess pr = new TestProcess();

pr.Id = id;
pr.UpdateID = updateID;

context.Attach(pr);
context.ObjectStateManager.ChangeObjectState(pr, EntityState.Modified);
context.SaveChanges();
于 2013-07-02T13:42:46.810 回答
1

编码:

TestProcess testprocess = dbcontext.TestProcesses.Attach(new TestProcess { MyID = id });
tp.UpdateID = updateID;
dbcontext.Entry<TestProcess>(testprocess).Property(tp => tp.UpdateID).IsModified = true;
dbcontext.Configuration.ValidateOnSaveEnabled = false;
dbcontext.SaveChanges();

结果 TSQL:

exec sp_executesql N'UPDATE [dbo].[TestProcesses]
SET [UpdateID] = @0
WHERE ([MyID] = @1)
',N'@0 bigint,@1 bigint',@0=2,@1=1

笔记:

需要“IsModified = true”行,因为当您创建新的 TestProcess 对象(仅填充了 MyID 属性)时,所有其他属性都有其默认值(0、null 等)。如果您想用“默认值”更新数据库,实体框架将不会检测到更改,然后数据库将不会被更新。

例如:

testprocess.UpdateID = null;

没有“IsModified = true”行将无法工作,因为当您创建空的TestProcess 对象时,属性UpdateID 已经为null,您需要告诉EF 该列必须更新,这就是该行的目的。

于 2017-06-15T21:05:41.987 回答