我试图在EF Core 2.0中开展软删除行为.
public interface ISoftDeleteModel
{
bool IsDeleted { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
创建正确的列和软删除工作正常,但DbContext中的过滤实体不是.
我想在上下文中使用查询过滤,但我被卡住了.
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
Type entityType;
// ^^^ it contains type of entity, eg. Blog, Post, etc. using
// modelBuilder.Model.GetEntityTypes().First().Name and converting to Type
var entity = modelBuilder.Entity(entityType);
if(entityType.GetInterface("ISoftDeleteModel") != null)
{
// ??? how to access IsDeleted property ???
entity.HasQueryFilter(x => !x.IsDeleted);
}
}
Run Code Online (Sandbox Code Playgroud)
问题很简单 - 如何访问IsDeleted属性?
如果我知道实体的类型,例如.Post和Post实现的ISoftDeleteModel我可以这样做:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Post>().HasQueryFilter(x => !x.IsDeleted);
}
Run Code Online (Sandbox Code Playgroud)
但我不知道这种类型.我试图实现简单的事情 - 所有实现此接口的模型都将被自动过滤.我错过了什么吗?