ef core實現軟刪除


很多web程序一般的偶不會設計真的物理刪除了。

基本上都是在在數據庫加一個標記,就得當作已經刪除了。同時在查詢的時候,過濾已經標記刪除的數據

ef core實現軟刪除是非常簡單的,直接在OnModelCreating動態創建一個IsDeleted字段,bool類型。然后扔到ef core的查詢過濾器里面去。

 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。

  ChangeTracker.DetectChanges();
            foreach (var item in ChangeTracker.Entries().Where(e => e.State == EntityState.Deleted)) { item.State = EntityState.Modified; item.CurrentValues["IsDeleted"] = true; }

這樣可以做到在EF中無感知軟刪除了!

如果需要在查詢中查詢出已經軟刪除的數據,直接加上 
IgnoreQueryFilters 就行了

blogs = db.Blogs
    .Include(b => b.Posts) .IgnoreQueryFilters() .ToList();

這樣就會把軟刪除的數據都查詢出來。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM