Entity framework DbContext update value without query and by foreign key

前端 未结 3 1660
天命终不由人
天命终不由人 2021-01-19 19:08

I have a method for updating some tables. For update I need get first of TestProcess, but I don\'t like that. How can I update TestProcess without

相关标签:
3条回答
  • 2021-01-19 19:34
    TestProcess pr = new TestProcess()
    {
        MyID == id,
    };
    
    context.Set<TestProcess>().Attach(pr);
    
    pr.UpdateID = updateID;
    
    context.SaveChanges();
    

    If you are setting the value to the default value of that type (for example, setting an int to 0) it won't be picked up as a change, and you need to manually set the state.

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

    You can put such code away in extension methods, so you can do things like this (I'll leave the implementation as an exercise):

    Foo entity = this.DbContext.GetEntityForUpdate<Foo>(
        item => item.ID, model.ID
        );
    
    this.DbContext.UpdateProperty(entity, item => item.Name, model.Name);
    
    0 讨论(0)
  • 2021-01-19 19:46

    You can do like that (you probably should have all the test process data):

    TestProcess pr = new TestProcess();
    
    pr.Id = id;
    pr.UpdateID = updateID;
    
    context.Attach(pr);
    context.ObjectStateManager.ChangeObjectState(pr, EntityState.Modified);
    context.SaveChanges();
    
    0 讨论(0)
  • 2021-01-19 19:47

    The code:

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

    The result TSQL:

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

    Note:

    The "IsModified = true" line, is needed because when you create the new TestProcess object (only with the MyID property populated) all the other properties has their default values (0, null, etc). If you want to update the DB with a "default value", the change will not be detected by entity framework, and then DB will not be updated.

    In example:

    testprocess.UpdateID = null;
    

    will not work without the line "IsModified = true", because the property UpdateID, is already null when you created the empty TestProcess object, you needs to say to EF that this column must be updated, and this is the purpose of this line.

    0 讨论(0)
提交回复
热议问题