【发布时间】:2011-07-19 01:08:24
【问题描述】:
我正在使用带有 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.米特夫
【问题讨论】: