我有支持软删除的 EF Code First 解决方案,因此我们将实体标记为 IsDeleted,而不是将它们从数据库中删除。我想调整相关对象的集合(延迟加载),以便标记为已删除的实体不会返回给 API 用户。
这是我使用的简单方法:
public class FilteredCollection<T> : ICollection<T> where T : DeletableEntity
{
private List<T> _listWithDeleted = new List<T>();
protected IEnumerable<T> FilteredItems
{
get { return _listWithDeleted.Where(e => e.IsDeleted == false); }
}
protected bool _IsReadOnly;
public virtual T this[int index]
{
get
{
return FilteredItems.ToList()[index];
}
set
{
FilteredItems.ToList()[index] = value;
}
}
public virtual int Count
{
get
{
return FilteredItems.Count();
}
}
public virtual bool IsReadOnly
{
get
{
return _IsReadOnly;
}
}
public virtual void Add(T entityObject)
{
_listWithDeleted.Add(entityObject);
}
public virtual bool Remove(T entityObject)
{
if (FilteredItems.Contains(entityObject))
{
entityObject.IsDeleted = true;
return true;
}
else
{
return false;
}
}
public bool Contains(T entityObject)
{
return FilteredItems.Contains(entityObject);
}
public virtual void CopyTo(T[] entityObjectArray, int index)
{
var list = FilteredItems.ToList();
list.CopyTo(entityObjectArray, index);
}
public virtual void Clear()
{
foreach (var item in _listWithDeleted)
{
item.IsDeleted = true;
}
}
public virtual IEnumerator<T> GetEnumerator()
{
return FilteredItems.GetEnumerator();
}
IEnumerator IEnumerable.GetEnumerator()
{
return FilteredItems.GetEnumerator();
}
}
我已经实现了 ICollection,所以它在内部过滤对象。我使用此类而不是 ICollection,因此将过滤的实体返回给我。我做了一些测试,看起来效果很好,但我对这个解决方案感到不舒服。
您能否向我提供这种方法的缺点,或者如果您知道更好的方法,请提出建议。
预先感谢,
-石油