在不维护数据库上下文的情况下检索和修改实体?

时间:2012-04-10 14:14:39

标签: c# wpf entity-framework

我是实体框架的新手。我正在使用WPF应用程序中的数据库。我在this blog中创建了一个模型,现在我想在我的应用程序中使用它。

我知道如何检索和修改这样的实体:

DatabaseContext ct = new DatabaseContext();
var person = ct.Persons.Find(1);
person.Name = "NewName";
ct.SaveChanges();

但是,在等待用户输入的应用程序中,这意味着在ViewModel中保留datacontext,这不是很理想。相反,我想做这样的事情:

class PersonViewModel {

    Person psn;

    public PersonViewModel(int PersonId) {
         DatabaseContext ct = new DatabaseContext();
         psn = ct.Persons.Find(1);
    }

    public Save() {
        DatabaseContect ct = new DatabaseContext();
        ct.Persons.Update(psn); // (There is no Update() method.)
        ct.SaveChanges();
    }

}

我不知道如何做Update()

我将DatabaseContext定义如下:

public partial class DatabaseContext: DbContext
{
    public DbSet<Person> Persons { get; set; }
}

但我似乎没有DatabaseContext.ObjectStateManager,有些人在解决类似问题时会使用{{1}}。我不知道为什么这是 - 它与使用POCO对象有关吗?

我该如何解决这个问题?

3 个答案:

答案 0 :(得分:2)

作为附件的替代方案:

public Save() {
    DatabaseContect ct = new DatabaseContext();
    ct.Entry(psn).State = EntityState.Modified;
    ct.SaveChanges();
}

答案 1 :(得分:1)

您需要使用Attach()方法。您可以在此处找到更多详细信息:http://msdn.microsoft.com/en-us/library/bb896248.aspx

 ct.Persons.Attach(psn); // instead of Update()

事情可能会变得更复杂,因为附加对象将处于未更改状态,您需要将其更新为已修改。

答案 2 :(得分:1)

您可以使用Attach method

public Save() {
    using(DatabaseContect ct = new DatabaseContext())
    {
      ct.Persons.Attach(psn);
      ct.SaveChanges();
    }
}