2

我有一个包含此方法的通用存储库:

public void Delete<T>(T item) where T : EntityBase

我正在尝试向某些对象添加软删除行为;IE。删除时,它们不会从数据库中删除,而是bool Deleted设置为afalse并且它们停止显示在查询中,除非将特定参数设置为包含它们。一般来说,应用程序的行为就好像它们不存在一样,除了管理视图,这些项目可以通过再次翻转该布尔值来恢复。我的问题是,在将对象传递给此方法时,它被处理为EntityBase,它没有这种软删除行为,因为许多类不需要它。SoftDeleteEntityBase扩展EntityBase类以添加软删除行为,但我找不到一种干净的方法来转换对象,以便我可以得到布尔值。我的第一个想法是这样的:

public void Delete<T>(T item) where T : EntityBase
{
    if (item is SoftDeleteEntityBase)
    {
        ((SoftDeleteEntityBase)item).Deleted = true;
        Update<T>(item);
    }
    else
    {
        db.Set<T>().Remove(item);
    }
}

但这给了我错误"Cannot convert type T to SoftDeleteEntityBase"

我如何得到那个布尔值?

4

2 回答 2

2

这个简短的解决方案怎么样,但考虑更改存储库的设计

SoftDeleteEntityBase itemAsSoft = item as SoftDeleteEntityBase;
if (itemAsSoft != null)
{
    itemAsSoft.Deleted = true;
    Update(itemAsSoft);
}

我不知道你的上下文,但是这个带有泛型的解决方案怎么样

void Main()
{
    Delete(new Base()); // called with base
    Delete(new Derived()); //called with derived
}
public void Delete(Base item)
{
    Console.WriteLine ("called with base");
    //one logic
    GenericDelete(item);
}

public void Delete(Derived item)
{
    Console.WriteLine ("called with derived");
    //another logic
    GenericDelete(item);
}

public void GenericDelete<T>(T item)
{}

public class Base
{}

public class Derived : Base
{}
于 2013-03-28T17:23:48.480 回答
1

理想情况下,您会利用多态性。类EntityBase可以有一个Delete方法;它和其他实现可以选择进行硬删除。该类SoftDeleteEntityBase可以覆盖该方法,而是选择只设置一个Deleted字段而不是硬删除它。那么这里的这个方法就不需要关心派生类型是什么了;它可以调用Delete并让班级自己选择。

于 2013-03-28T17:24:46.180 回答