我是实体框架的新手。我正在使用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对象有关吗?
我该如何解决这个问题?
答案 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();
}
}