zoukankan      html  css  js  c++  java
  • 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();

    这样就会把软删除的数据都查询出来。

  • 相关阅读:
    Cordova 混合开发
    可能比文档还详细--VueRouter完全指北
    VUE项目实现页面跳转
    Vuex结合 async/await 优雅的管理接口请求
    vuex深入理解 modules
    vuex学习与实践——mapState、getter、mapGetters
    vuex里mapState,mapGetters使用详解
    vue.js相关UI组件收集
    vuex最简单、最直白、最全的入门文档
    深入理解表单脚本系列第三篇——选择文本
  • 原文地址:https://www.cnblogs.com/boxrice/p/11670635.html
Copyright © 2011-2022 走看看