我正在使用带有WPF的Entity Framework 4.0 POCO。 我有一个表单向用户显示一个具有多对多关系的对象,如下所示:
public class BPartner : BaseEntity
{
public string Name
{
get { return name; }
set
{
if (name != value)
{
name = bpartnerValidatorLight.ValidateName(value);
OnPropertyChanged("Name",true);
}
}
}
public virtual ObservableCollection<BPAddress> BPAddresses { get; set; }
}
public class BPAddress : BaseEntity
{
public string Line1
{
get
{
return line1;
}
set
{
if (line1 != value)
{
line1 = bpAddressValidatorLight.ValidateLine1(value);
OnPropertyChanged("Line1",true);
}
}
}
public virtual City City
{
get { return city; }
set
{
if (city != value)
{
city = value;
OnPropertyChanged("City");
}
}
}
}
用户可以在BPAddresses集合中添加和删除地址,并更改BPartner的“名称”。当用户完成修改BPArtner对象时,他/她可以单击“保存”或“取消”。问题是当用户点击“取消”时,我需要告诉实体框架恢复所有更改。
处理此问题的任何方法都非常受欢迎,包括重新加载。
这是我尝试过的:
1.丢弃objectContext,创建一个新的对象上下文,然后只查询数据库以重新加载所有内容。这里的问题是实体框架缓存事物和旧对象留在旧上下文中,如果用户单击取消然后再次编辑并单击保存,我会得到例外。
2.
repoBPartner.Refresh(BP);
IQueryable<BPAddress> query = from e in addressRepo.AsQueryable()
where e.BPartnerId == bp.Id
select e;
ObjectQuery<BPAddress> objectQuery = (ObjectQuery<BPAddress>)query;
objectQuery.Include("City");
objectQuery.Include("Country");
ObjectResult<BPAddress> result = (ObjectResult<BPAddress>)objectQuery.Execute(MergeOption.OverwriteChanges);
bp.BPAddresses = new System.Collections.ObjectModel.ObservableCollection<BPAddress>(result.ToList<BPAddress>());
The problem here is that "City" property does not get refreshed.
3. Tried: objectContext.LoadProperty(bp, "BPAddresses", MergeOption.OverwriteChanges);
以上所有部分工作。实现这一目标的最佳做法是什么?
任何帮助将不胜感激。
谢谢, K. Mitev
答案 0 :(得分:2)
EF不提供丢弃更改。 EF也没有二级缓存,所以一旦你配置了一个带有更改的上下文并创建了一个新的上下文来从数据库加载数据,你将获得未更改的数据。
这里的问题是实体 框架缓存旧的东西 物体徘徊在旧的 上下文,我得到例外,如果 用户单击取消然后再次编辑 并点击保存。
当用户点击取消时,您必须丢弃编辑中使用的所有对象及其上下文。这些对象和背景都已死亡。用户再次单击编辑后,您必须再次从数据库加载所有内容。
刷新导航属性不能很好地工作。例如,一旦向导航集合中添加了某些内容,就不会通过从数据库中刷新来删除它。