不少web程序通常的偶不会设计真的物理删除了。web
基本上都是在在数据库加一个标记,就得看成已经删除了。同时在查询的时候,过滤已经标记删除的数据数据库
ef core实现软删除是很是简单的,直接在OnModelCreating动态建立一个IsDeleted字段,bool类型。而后扔到ef core的查询过滤器里面去。ide
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
foreach (var entityType in modelBuilder.Model.GetEntityTypes()) { entityType.GetOrAddProperty("IsDeleted", typeof(bool)); var parameter = Expression.Parameter(entityType.ClrType); var propertyMethodInfo = typeof(EF).GetMethod("Property").MakeGenericMethod(typeof(bool)); var isDeletedProperty = Expression.Call(propertyMethodInfo, parameter, Expression.Constant("IsDeleted")); BinaryExpression compareExpression = Expression.MakeBinary(ExpressionType.Equal, isDeletedProperty, Expression.Constant(false)); var lambda = Expression.Lambda(compareExpression, parameter); modelBuilder.Entity(entityType.ClrType).HasQueryFilter(lambda); } }
而后再保存的时候,扫描实体更改,把状态为Deleted的实体的状态修改成Modified,加上一个IsDeleted的字段,值为false。ui
ChangeTracker.DetectChanges();
foreach (var item in ChangeTracker.Entries().Where(e => e.State == EntityState.Deleted)) { item.State = EntityState.Modified; item.CurrentValues["IsDeleted"] = true; }
这样能够作到在EF中无感知软删除了!spa
若是须要在查询中查询出已经软删除的数据,直接加上
IgnoreQueryFilters 就好了设计
blogs = db.Blogs
.Include(b => b.Posts) .IgnoreQueryFilters() .ToList();
这样就会把软删除的数据都查询出来。code